码迷,mamicode.com
首页 > 编程语言 > 详细

谈一谈你对js线程的理解

时间:2018-06-25 16:50:44      阅读:155      评论:0      收藏:0      [点我收藏+]

标签:rip   回调函数   主线程   理解   cti   异步   执行顺序   IV   顺序   

js线程:javascript是单线程的,所有任务都需要排队,这些任务分为同步任务和异步任务,单线程上有一个主线程任务。同步任务必须再主线程上排队进行,而异步任务(类似于点击事件)必须在主线程上的任务全部进行完成后形成一个任务队列(将所有的触发事件放在一个任务队列中),这任务队列的任务也是需要排队的,当主线程任务完成后他们将通过触发事件按顺序加入到主线程进行任务。可以改变程序正常执行顺序的操作就可以看成是异步操作。

 

ajax 异步解释:ajax异步就是当任务队列存在ajax请求时,当任务走到ajax时,ajax传递参数给服务器,而不需要等数据传到后再执行下面的任务,而是让请求数据的时间继续进行下一个任务,从而表现为异步。其中浏览器为ajax新开一个线程请求,当数据请求到后将回调函数(success())继续放入任务队列中。

<script type="text/javascript">  
        console.log( "1" );  
        setTimeout(function() {  
            console.log( "2" )  
        }, 0 );  
        setTimeout(function() {  
            console.log( "3" )  
        }, 0 );  
        setTimeout(function() {  
            console.log( "4" )  
        }, 0 );  
        console.log( "5" );  
</script>

输出:1 5 2 3 4

例如: console.log( "1" ); console.log( "5" ); 就是同步任务, setTimeout就是异步任务,只有当1.5执行完后才开始执行2.3.4

 

谈一谈你对js线程的理解

标签:rip   回调函数   主线程   理解   cti   异步   执行顺序   IV   顺序   

原文地址:https://www.cnblogs.com/8080zh/p/9224446.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!