1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > 单线程JS与多线程浏览器的使用

单线程JS与多线程浏览器的使用

时间:2023-06-23 12:37:04

相关推荐

单线程JS与多线程浏览器的使用

web前端|js教程

javascript,Firefox,webkit

web前端-js教程JS语言是单线程的,浏览器只分配给js一个主线程,用来执行任务(函数),但一次只能执行一个任务,这些任务形成一个任务队列排队等候执行。

网页即时通信源码,ubuntu里获取路径,无法加载tomcat服务器,黑客爬虫桌面代码,零基础学习php笔记,优化seo重庆lzw

浏览器是多线程的

qq的安装包源码,ubuntu19花屏,tomcat的点滚动才执行,爬虫草的功效,php随机短信验证码,seo文章处理lzw

前端某些任务是非常耗时的,比如网络请求,定时器和事件监听,如果让他们和别的任务一样,都老老实实的排队等待执行的话,执行效率会非常的低,甚至导致页面的假死。所以,浏览器是多线程的,例如Webkit或是Gecko引擎,都可能有如下线程:

自助查询 源码,vscode终端自动换行,ubuntu增加pci,添加tomcat依赖,sqlite记录集是什么,爬虫中常见的9种错误,xml 和php,seo家居策划案,产品展示网站模板php,php 下载网页所有图片,dede图片模板下载lzw

javascript引擎线程

http请求线程

界面渲染线程

浏览器事件触发线程

JS单线程与Ajax异步

既然说JS是单线程运行的,那么为什么XMLHttpRequest在连接后是异步的?这是由浏览器新开一个线程请求。当请求的状态变更时,如果先前已设置回调,这异步线程就产生状态变更事件放到 JavaScript引擎的事件处理队列中等待处理。当浏览器空闲的时候出队列任务被处理,JavaScript引擎始终是单线程运行回调函数。javascript引擎确实是单线程处理它的任务队列,能理解成就是普通函数和回调函数构成的队列。

即Ajax请求确实是异步的,这是由浏览器新开一个线程请求,事件回调的时候是放入Event loop单线程事件队列等候处理。

JS事件循环机制(Event loop)

Javascript有一个main thread 主进程和call-stack(一个调用堆栈),在对一个调用堆栈中的task处理的时候,其他的都要等着。当在执行过程中遇到一些类似于setTimeout等异步操作的时候,会交给浏览器的其他模块(以webkit为例,是webcore模块)进行处理,当到达setTimeout指定的延时执行的时间之后,task(回调函数)会放入到任务队列之中。一般不同的异步任务的回调函数会放入不同的任务队列之中。等到调用栈中所有task执行完毕之后,接着去执行任务队列之中的task(回调函数)。

在上图中,调用栈中遇到DOM操作、ajax请求以及setTimeout等WebAPIs的时候就会交给浏览器内核的其他模块进行处理,webkit内核在Javasctipt执行引擎之外,有一个重要的模块是webcore模块。对于图中WebAPIs提到的三种API,webcore分别提供了DOM Binding、network、timer模块来处理底层实现。等到这些模块处理完这些操作的时候将回调函数放入任务队列中,之后等栈中的task执行完之后再去执行任务队列之中的回调函数。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。