node thread.sleep实现示例
最近在写一些奇怪的东西的时候,发现大佬们用go或者其他语言实现的并发任务用了thread.sleep让主进程暂停。
回头一想,妈个鸡我要复制粘贴到node一直循环不合适啊,我也需要暂停来着!
怎么办??
抓了脑袋一会去npm上找了下相关的包,发现有个叫thread-sleep的包,下载量还挺高。
抱着好奇心去看了下源码,又发现源码相当之骚气
'use strict'; var childprocess = require('child_process'); var nodebin = process.argv[0]; module.exports = sleep; function sleep(milliseconds) { var start = date.now(); if (milliseconds !== math.floor(milliseconds)) { throw new typeerror('sleep only accepts an integer number of milliseconds'); } else if (milliseconds < 0) { throw new rangeerror('sleep only accepts a positive number of milliseconds'); } else if (milliseconds !== (milliseconds | 0)) { throw new rangeerror('sleep duration out of range') } milliseconds = milliseconds | 0; var shouldend = start + milliseconds; try { childprocess.execfilesync(nodebin, [ '-e', 'settimeout(function() {}, ' + shouldend + ' - date.now());' ], { timeout: milliseconds, }); } catch (ex) { if (ex.code !== 'etimedout') { throw ex; } } var end = date.now(); return end - start; }
黑人问号???
这是什么奇怪的实现。
翻阅node文档发现
synchronous process creation#
the child_process.spawnsync(),
child_process.execsync(), and child_process.execfilesync() methods are synchronous and will block the node.js event loop,
pausing execution of any additional code until the spawned process exits.blocking calls like these are mostly useful for simplifying general-purpose scripting tasks and for simplifying the loading/processing of application configuration at startup.
???
以上三种同步方法会阻塞nodejs的事件循环,除非创建的子进程执行完了,才会继续执行下面的代码。
thread-sleep包的作者正是利用这一特性实现了sleep功能。叹为观止
所以很多时候我们没办法解决现有问题的原因是对文档不熟么??
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: 一些经典社会笑话
下一篇: 婚姻大事,动物心里都有小算盘