摩尔定律:
我们知道我们的多线程是在多核CPU的硬件条件下。我们现在的电脑一般都是起码四核的。我看一下我的电脑是几核的:
没记错的话,插槽的个数应该指的是CPU的个数,而逻辑处理器指的应该是CPU的核心数。
所以那为什么要使用多线程呢?
1、充分利用CPU的计算能力
我们的CPU是多核的,闲着也是闲着,为什么不利用起来呢?我们要把CPU的计算能力发挥到极致。线程是大多数操作系统调度的基本单元,一个程序作为一个进程来运行,程序运行过程中能够创建多个线程,而一个线程在一个时刻只能运行在一个处理器核心上。试想一下,一个单线程程序在运行时只能使用一个处理器核心,那么再多的处理器核心加入也无法显著提升该程序的执行效率。相反,如果这个程序使用多线程技术,将计算逻辑分配到多个处理器核心上,就会显著减少程序的处理时间,并且随着更多处理器核心的加入而变得更有效率。
2、更快的响应时间
有些业务天生就适用于多线程。(比如复杂的业务逻辑,电商业务逻辑都是比较复杂的),例如,一笔订单的创建,它包括插入订单数据、生成订单快照、发送邮件通知卖家和记录货品销售数量等。用户从单击“订购”按钮开始,就要等待这些操作全部完成才能看到订购成
功的结果。但是这么多业务操作,如何能够让其更快地完成呢?在上面的场景中,可以使用多线程技术,即将数据一致性不强的操作派发给其他线程处理(也可以使用消息队列),如生成订单快照、发送邮件等。这样做的好处是响应用户请求的线程能够尽可能快地处理完成,缩短了响应时间,提升了用户体验。
3、更好的编程模型
Java为多线程编程提供了良好、考究并且一致的编程模型,使开发人员能够更加专注于问题的解决,即为所遇到的问题建立合适的模型,而不是绞尽脑汁地考虑如何将其多线程化。一旦开发人员建立好了模型,稍做修改总是能够方便地映射到Java提供的多线程编程模型上。
文章参考了<Java并发编程的艺术>