java并发1-线程的优点和缺点

本文深入探讨了线程在多核CPU环境下发挥的强大处理能力,以及如何通过线程简化业务处理建模和异步事件处理。同时,文章也剖析了线程可能带来的风险,包括安全性问题、死锁现象及上下文切换导致的性能损耗。

线程的优点

1.发挥多核CPU强大处理能力
2.业务处理建模的简单性
通过使用线程,可以将复杂且异步的工作流进一步分解为一组简单并同步的工作流,每个工作流在一个单独的线程中运行,并在特定的同步位置进行交互。
3.异步事件的简化处理
服务端接受多个客户端socket连接请求时,如果为每个连接都分配一个线程并且使用同步IO,会降低编程的开发难度,同时现代操作系统,线程数量已得到极大提升,如:NPTL线程软件包是个专门设计用于支持数十万个线程的,大多数Linux发布版本中都包含这个软件包。

线程的风险

1.安全性问题
2.死锁(网上例子非常多)

public class LeftRightDeadlock {
    private final Object left = new Object();
    private final Object right = new Object();
    public void leftRight() {
        // 得到left锁
        synchronized (left) {
            // 得到right锁
            synchronized (right) {
                doSomething();
            }
        }
    }
    public void rightLeft() {
        // 得到right锁
        synchronized (right) {
            // 得到left锁
            synchronized (left) {
                doSomethingElse();
            }
        }
    }
}

这里有专门讲死锁,还不错:
https://www.jianshu.com/p/68c0fef7b63e
3.频繁的上下文切换带来的性能问题
多线程中,线程的挂起并运行另一个线程时就会出现上下文切换操作(Context Switch),这种操作将带来极大的开销:保存和恢复执行上下文,丢失局部性,如果频繁进行上下文切换,CPU时间更多的花在线程调度上,而不是线程运行上。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值