多线程为什么跑的比单线程还要慢?

文章探讨了多线程与单线程的执行效率问题,指出多线程并不总是比单线程快,因为多线程涉及上下文切换,可能导致额外的时间消耗。在单核CPU中,多线程的总体执行时间可能与单线程相同,但并发处理能力增强。上下文切换是指CPU在不同线程间切换时保存和恢复状态的过程。作者强调了扎实的技术基础的重要性,计划从Java虚拟机开始深入学习。
摘要由CSDN通过智能技术生成

前言:
面试官:多线程和单线程哪个快?
我凭借微弱的记忆以及正经分析回答:多线程快,因为可以执行多个任务,而单线程只能执行一个任务。
面试官:无论什么情况多线程都比单线程快吗?
我犹豫了一下正经回答:不是的,线程执行消耗的是cpu的,cpu资源是有限的,所有不是一直比单线程快。
面试官:那什么情况下单线程比多线程快?
我…:这…不清楚。
面试官:你没有学过《计算机基础》吗?你已经自相矛盾了…
我:没学过,好吧,我不知道。
后来这个面试官变成了我的老大,技术总监,进公司第一天下午讨论某问题之后单独叫我谈话。
老大问我那个问题有没有去了解过。
我虚了:我看了,不一定,多线程存在上下文切换。
老大:多线程一定比单线程慢,上下文切换你知道什么意思吗?
我心想完了:额…看了忘记了。
然后噼里啪啦跟我解释,我现在依旧忘记了…

正文:
回家后我再次查阅资料:

首先分配cpu资源的单位是进程。一个进程所获得到的cpu资源是一定的。程序在执行的过程中消耗的是cpu,比如一个单核cpu,多个线程同时执行工作时,需要不断切换执行(上下文切换),单个线程时间耗费更多了,而单线程只是一个线程跑。
比如:
处理10个报表,
在单线程的情况下,假如说我们生成10个报表文件需要1个小时。
单线程是先执行完第一个报表,用了6分钟,再执行第二个报表,也用6分钟。总计1个小时
多线程,是10个报表一起执行,但是每一个报表都要1个小时。
总结:多线程的总体执行时间和单线程是一样的,但是多线程中单个线程的执行时间是单线程的多倍。
多线程提高的是并发数量,比如现在有一个4核cpu的服务器,同一时间可执行4个线程,这样处理线程任务的速度比较快。但是多出来的线程,5个,6个,7个,多出的线程还是要等待。

上下文切换
多线程编程中一般线程的个数都大于 CPU 核心的个数,而一个 CPU 核心在任意时刻只能被一个线程使用,为了让这些线程都能得到有效执行,CPU 采取的策略是为每个线程分配时间片并轮转的形式。当一个线程的时间片用完的时候就会重新处于就绪状态让给其他线程使用,这个过程就属于一次上下文切换。

概括来说就是:当前任务在执行完 CPU 时间片切换到另一个任务之前会先保存自己的状态,以便下次再切换会这个任务时,可以再加载这个任务的状态。任务从保存到再加载的过程就是一次上下文切换。

后记:
基础不牢固的情况下去回答问题是非常容易打脸的,回答出的答案也是稀里糊涂的,稍微换个角度攻击就会一脸懵逼,学习更多的新技术其实没太大用处,因为这个行业技术迭代的很快,基础才是永久的饭碗,所以我决定从java虚拟机开始入手,修炼内功,找对方向获得会更多!
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值