Java中多线程为什么有时候线程越多越慢

最近在公司一个项目中遇到一个获取外部接口的需求,由于外部接口返回速度过慢,就想采取多线程分片获取数据再统一处理,但是发现,线程创建得越多,他的返回速度就越慢。这是为什么?不应该是线程越多越快吗?

上网查阅资料发现以下几点

当CPU在多个线程之间切换时,需要进行上下文切换。在上下文切换的过程中,CPU会进行一些额外的工作,如保存当前线程的上下文、加载新线程的上下文、更新线程控制块等。这些操作会消耗一定的时间和资源,因此,上下文切换的开销越大,系统的性能就越低。

因此这就是为什么线程创建越多,而效率却越来越慢了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值