最近在公司一个项目中遇到一个获取外部接口的需求,由于外部接口返回速度过慢,就想采取多线程分片获取数据再统一处理,但是发现,线程创建得越多,他的返回速度就越慢。这是为什么?不应该是线程越多越快吗?
上网查阅资料发现以下几点
当CPU在多个线程之间切换时,需要进行上下文切换。在上下文切换的过程中,CPU会进行一些额外的工作,如保存当前线程的上下文、加载新线程的上下文、更新线程控制块等。这些操作会消耗一定的时间和资源,因此,上下文切换的开销越大,系统的性能就越低。
因此这就是为什么线程创建越多,而效率却越来越慢了。