多线程优势和问题详解
扫描二维码
随时随地手机看文章
多线程的优势:
可并行处理任务,减少单个任务的等待时间;
线程较进程开销更小;
线程间可共享资源;
多核情况下可充分利用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、性能开销:
锁竞争、上下文切换开销、内存开销