客服端JavaScript线程模型
JavaScript语言核心并不包含任何线程机制,并且客服端JavaScript传统上没有定义任何线程机制。HTML5定义了一种作为后台线程的“WebWorker",但是客服端JavaScript还像严格的单线程一样工作。甚至当可能并发执行的时候,客服端JavaScript也不知晓是否真的有并行逻辑的执行。
单线程执行是为了让编程更加简单。编写代码时可以确保两个事件处理程序不会同一时刻运行,操作文档内容也不会担心会有其他线程试图同时修改文档,并且永远不需要在写JavaScript时担心锁,死锁和竞态条件。
单线程执行意味着浏览器必须在脚本和事件处理程序 的时候停止响应用户输入。这意味着JavaScript脚本和事件处理程序不能运行太长时间。如果一个脚本执行计算密集的任务,它将给文档载入带来延迟,而用户无法在脚本完成前看到文档内容。如果事件处理程序执行计算密集的任务,浏览器可能变得无法响应,可能导致用户认为浏览器崩溃了。
如果应用程序非要执行太多的计算而导致明显的延迟,应该允许文档在执行这个计算前完全载入,并确保告知用户计算正在进行并且浏览器没有挂起。如果可能将计算分解为离散的子任务,可以使用settimeout()和setInterval()在后台允许子任务。
好久没有更新博客了。之后会带来更为干活的内容。
分享技术的奥秘,共同平等的提高。