多线程开发用了很久,但是一直没去深入了解。长久以来一直有一些迷惑。直到深入了解后,才发现了以前的理解有不少错误的地方。
单线程等于同步,多线程等于异步
这种理解很直观,毕竟只有一个线程怎么异步?
Node.js表示不服,我就是单线程,我也能异步。谈一谈Node中的异步和单线程。
看完这篇文章我明白了单线程也能异步,把IO等耗时的操作比作烧水,我可以在这个时候切菜,这就是异步啊。
等等,似乎有点不对,那io又谁来开启,又谁来通知cpu我已经结束了呢?
Node.js异步IO的实现,这篇文章解决了我的疑惑。
Node.js里面只有自己写的代码是跑在主线程上,但是内部并不是单线程的,由C编写的底层开启了线程做IO操作。
恍然大悟,我现在的理解就是,会有一个可运行的线程池在等待cpu的使用权。类似IO,网络请求这种耗时干等的操作,线程会放到需要等待的线程池中(阻塞),不会获取cpu的使用权,直到操作完成
这个理解了,并发和并行就很容易了。