JavaScript 的代码是运行在单线程上的,也就是说同一时刻只能有一个操作被执行。这样的益处是不必思考并发问题,只需关注写得代码不要阻塞线程。

通常状况,大多数浏览器当你关上一个tab就会开启一个Event Loop,而且每个网页之间是断绝的,能够避免出现阻塞线程时导致整个浏览器卡死。

如果你对之前提到的异步、同步还有印象,那么咱们能够这样认为:阻塞的办法是以同步执行(synchronously),非阻塞办法以异步模式执行(asynchronously)。

以 Node.js 的文件操作为例:

// 1. 应用同步的形式读取文件const fs = require('fs');const data = fs.readFileSync('/file.md'); // 程序会始终阻塞晓得文件读取实现console.log(data);moreWork(); // 直到下面的console.log执行完 能力做其余的工作// 2. 应用异步模式读取文集const fs = require('fs');fs.readFile('/file.md', (err, data) => {  if (err) throw err;  console.log(data);});moreWork(); // 在console.log之前就能够做其余工作

Blocking/Non-Blocking

如果读取的文件很大,在读取实现之前,同步模式的代码将不能向下执行,这时就产生了阻塞。

Node.js应用回调来防止程序产生阻塞,使程序能够同一时间解决更多的工作。

咱们思考这样一种状况:每个对 Web 服务器的申请须要 50 毫秒实现,而那 50 毫秒中的 45 毫秒是能够异步执行的数据库 I/O。抉择 非阻塞 异步操作能够开释每个申请的 45 毫秒来解决其它申请。仅仅是抉择应用 非阻塞 办法而不是 阻塞 办法,就能造成并发的显著差别。

事件循环不同于许多其余语言的模型,其它语言创立额定线程来解决并发工作。Node.js 提供了一系列的异步I/O办法来防止线程阻塞。

如何防止线程阻塞?

JavaScript中简直所有的I/O操作都是非阻塞的(Non-Blocking),比方:网络申请,文件系统操作。这也是JavaScript十分依赖于回调函数(Callbacks)、Promises、Async/Await 的起因。

咱们在编程时应用下面的办法就能够无效防止线程阻塞。

参考链接

https://nodejs.org/en/docs/gu...

文章首发于 IICOOM-集体博客 《JavaScript阻塞与非阻塞》