关于javascript:JavaScript阻塞与非阻塞

5次阅读

共计 1043 个字符,预计需要花费 3 分钟才能阅读完成。

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 阻塞与非阻塞》

正文完
 0