多线程到底是怎么提速的?

我是没明白,即使是多线程,那也是一个CPU时间片接一个的运行,实际上还是一个串行的过程,那么为什么多线程之后就能提速了呢?... 我是没明白,即使是多线程,那也是一个CPU时间片接一个的运行,实际上还是一个串行的过程,那么为什么多线程之后就能提速了呢? 展开
 我来答
yy_galois
2013-09-24 · TA获得超过857个赞
知道小有建树答主
回答量:429
采纳率:100%
帮助的人:160万
展开全部
这个主要是效率问题。

比如线程A专门读写磁盘文件,相对于CPU的执行速度,cpu基本 0.0001ns就能执行一次指令,而一次磁盘读取,可能需要几百个us,甚至几十个ms,相当于几百万个cpu周期,甚至上亿个cpu周期。A读取磁盘的时候,并不需要cpu参与。

如果没有多线程,那么cpu就在这里闲着没事。此时如果有线程B,比如执行一个计算程序,计算555x888=多少,因为这个程序不需要用到磁盘读取(要用到内存,但是不需要用到磁盘,只要不用到磁盘即可,这样就不会和A冲突)。此时B就可以运行了。

此时A其实也在执行,只是相对于CPU而言,A没用到CPU,CPU认为它不在运行。

效率就提高了。
中智咨询
2024-08-28 广告
在当今竞争激烈的商业环境中,企业需要不断提高自身的竞争力,以保持市场份额和增加利润。通过人效提升,企业可以更有效地利用有限的资源,提高生产力和效益,从而实现盈利目标。中智咨询提供全方位的组织人效评价与诊断、人效提升方案等数据和管理咨询服务。... 点击进入详情页
本回答由中智咨询提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式