多线程的优势:

可并行处理任务,减少单个任务的等待时间;

线程较进程开销更小;

线程间可共享资源;

多核情况下可充分利用CPU资源。发挥多处理器的强大性能,提升资源利用率以及系统的吞吐率。

提供更好的GUI交互体验(如腾讯视频可边下边播)

充分利用服务器硬件资源;

提高服务吞吐量、降低响应时间;

分布式系统;

资源的争用、可伸缩性;

多线程并发内存消耗比较少;

每个线程需要一个Thread stack保存线程场景,Thread stack一般需要十几到几十kb内存,不像多进程,每个进程需要加载完整的应用环境,需要分配十几到上百MB内存。

线程可以共享资源,特别是可以共享整个应用环境,不必像进程每个进程要加载应用环境。

多线程并CPU消耗比较小。

线程的场景切换小于进程的场景切换。

很容易创建和高效利用共享资源。

数据库线程池。

字典表,进程内缓存。

IO并发能力很高。

java VM可以轻松维护几百个并发线程的线程切换开销,远高于多进程单服务器上几十个并发的处理能力。

可有效利用多核CPU,实现并行运算。


多线程带来的问题:

1、VM 的内存管理要求超高,对内存管理要求非常高,应用代码稍不注意,就会产生OOM,需要应用代码长期和内存泄漏做斗、争。GC的策略会影响多线程并发能力和系统吞吐量,需要对GC策略和调优有很好的经验。

在大内存服务器上的物理内存利用率问题。VM内存堆不宜过大,一般2GB为宜。过大的内存堆或造成GC效率下降。在物理内存很多的服务器上为了有效利用更多内存,不得不跑多个java VM,增加了复杂度。

对共享资源的操作。对共享资源的操作要非常小心,特别是修改共享资源需要加锁操作,很容易引发死锁问题。

应用代码和第三方库都必须是线程安全的。使用了非线程安全的库会造成各种潜在难以排查的问题。

单进程多线程模型不方便通过操作系统管理。一旦出现死锁或者线程阻塞很容易导致整个VM进程挂起失去响应,隔离性很差。

2、设计更复杂:

资源共享、数据一致性及可见性、调试困难;线程安全问题。

3、性能开销:

锁竞争、上下文切换开销、内存开销