JS中的异步、同步

异步同步

1.1什么叫异步呢什么叫同步呢?

异步(async)任务:异步任务是指不进入主线程,而进入任务队列的任务,只有任务队列通知主线程,某个异步任务可以执行了,该任务才会进入主线程,当我们打开网站时,像图片的加载,音乐的加载,其实就是一个异步任务
同步任务:同步任务是指在主线程上排队执行的任务,只有前一个任务执行完毕,才能继续执行下一个任务,当我们打开网站时,网站的渲染过程,比如元素的渲染,其实就是一个同步任务。

setTimeout(function cbFn(){
    console.log('learnInPro');
}, 1000);
 
console.log('sync things');

setTimeout就是一个异步任务,当JS引擎顺序执行到setTimeout的时候发现他是个异步任务,则会把这个任务挂起,继续执行后面的代码。直到1000ms后,回调函数cbFn才会执行,这就是异步,在执行到setTimeout的时候,JS并不会的等着1000ms执行cbFn回调函数,而是继续执行了后面的代码。

1.2 为啥要在JS中使用异步

由于javascript是单线程的,只能在JS引擎的主线程上运行的,所以js代码只能一行一行的执行,不能在同一时间执行多个js代码任务,这就导致如果有一段耗时较长的计算,或者是一个ajax请求等IO操作,如果没有异步的存在,就会出现用户长时间等待,并且由于当前任务还未完成,所以这时候所有的其他操作都会无响应。

1.3 JavaScript中的异步是怎么实现的呢?那要需要说下回调和事件循环这两个概念啦

首先要先说下任务队列,异步任务是不会进入主线程,而是会先进入任务队列,任务队列其实是一个先进先出的数据结构,也是一个事件队列,比如说文件读取操作,因为这是一个异步任务,因此该任务会被添加到任务队列中,等到IO完成后,就会在任务队列中添加一个事件,表示异步任务完成啦,可以进入执行栈啦~但是这时候呀,主线程不一定有空,当主线程处理完其它任务有空时,就会读取任务队列,读取里面有哪些事件,排在前面的事件会被优先进行处理,如果该任务指定了回调函数,那么主线程在处理该事件时,就会执行回调函数中的代码,也就是执行异步任务啦!
单线程从任务队列中读取任务是不断循环的,每次栈被清空后,都会在任务队列中读取新的任务,如果没有任务,就会等到,直到有新的任务,这就叫做任务循环,因为每个任务都是由一个事件触发的,因此也叫作事件循环。

异步机制的执行步骤如下:

  • 所有同步任务都在主线程上执行,行成一个执行栈
  • 主线程之外,还存在一个任务队列,只要异步任务有了结果,就会在任务队列中放置一个事件
  • 一旦执行栈中的所有同步任务执行完毕,系统就会读取任务队列,看看里面还有哪些事件,那些对应的异步任务,于是结束等待状态,进入执行栈,开始执行
  • 主线程不断的重复上面的第三步
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在JavaScript,异步(asynchronous)和同步(synchronous)是关于代码执行顺序的两个概念。 同步指的是代码按照顺序执行,每行代码在前一行代码执行完之后才会执行。这意味着在执行一个耗时的操作时,其他代码会被阻塞,直到该操作完成。 异步指的是代码可以在执行耗时操作时继续执行后续代码,而不需要等待操作完成。异步操作通常会通过回调函数、Promise、async/await等方式来处理。通过异步操作,代码可以在等待某个操作完成的同时继续执行其他任务,从而提高了代码的效率和用户体验。 举个例子来说明: - 同步操作:如果有一个耗时的函数调用,后续的代码会一直等待该函数执行完才会执行。 ``` console.log('开始'); 耗时操作(); // 这里会一直等待耗时操作执行完 console.log('结束'); ``` - 异步操作:如果有一个异步的函数调用,后续的代码会继续执行,而不需要等待异步操作完成。 ``` console.log('开始'); 异步操作(() => { console.log('异步操作完成'); }); console.log('结束'); ``` 在异步操作的例子,'异步操作完成'可能会出现在'结束'之前,因为异步操作是在后台进行的。 需要注意的是,JavaScript的事件处理、定时器、网络请求等操作通常是异步的,因为它们需要等待某些外部资源或事件触发才能执行。同时,JavaScript也提供了一些机制(如回调函数、Promise和async/await)来处理异步操作,以便更好地管理和控制代码执行顺序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值