单核、多线程与时间片,以Node.js为例

  去年写了篇文章《线程与进程的理解》,当时认为线程和CPU的单核多核无关,操作系统可以有很多个线程。但今天看《深入浅出Node.js》一书时,多次提到单线程无法利用多核CPU一类的。顿时又有疑惑了,操作系统的线程还是与

CPU核数有关?带着这个问题,搜了一些资料研究。Node.js的异步I/O实现,是让一个线程进行计算处理,部分线程进行阻塞或非阻塞I/O加轮询技术完成数据的获取,通过线程之间的通信将I/O得到的数据进行传递。注意,我们平常提到的

Node.是单线程的,这里的单线程仅仅只是JS执行在单线程中罢了。单核CPU开启多个线程,是给每个线程分配时间片,但同时只会有一个线程运行,这个线程的时间片用完,就进入其他线程。操作系统通过线程的优先级来使单核CPU的

多线程可以正常进行。

参考 https://bbs.csdn.net/topics/380078895

猜你喜欢

转载自www.cnblogs.com/zhansu/p/9221635.html