进程与线程
我们在电脑中会运行多个程序,每一个程序中都会有多个线程。
例如我们运行比特币客户端的时候,我们某一个线程要处理网络、某一个线程要处理挖矿、某一个线程要处理用户输入…
线程的调度使用了操作系统级别的调度器来明确了哪一个线程应该被执行。线程也有优先级之分,例如监听鼠标滑动的优先级就会很高,因为其不能等待太长的时间。
为了在给定的时间内更快更多的处理线程:
1、我们可以通过增加CPU的核心数量或者是
2、调度器当监测到线程中运行中断,如读取文件网络时,及时切换到其他的线程中执行。
事件循环
nodejs是单线程的事件循环机制
伪代码演示事件循环:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
const peningTimers =[]; const pendingOSTasks=[]; cosnt pendingOperations=[]; 1、初始化 myfile.runContent() function shouldContinue(){ //是否继续 1、检查setTimeOut、setInterval、setImmediate 2、检查是否有监听端口等操作系统级别的任务 3、检查是否有文件、网络等长期的操作 return peningTimers.length || pendingOSTasks.length || pendingOperations.length; } 2、事件循环 while(shouldContinue()){ //1.观察peningTimers.length,是否调查setTimeOut、setInterval等函数 //2、观察pendingOSTasks.length pendingOp |