两个线程交替执行+1,无锁化实现和synchronized 、condition实现的效率对比

本文探讨了在Java中,使用synchronized、Condition以及AtomicInteger实现两个线程交替加1操作的效率。在小循环次数下,synchronized效率最高,但随着循环次数增加,无锁化的AtomicInteger表现最优,而Condition实现的效率略逊一筹。在大量循环中,加锁机制的性能显著下降,无锁化方案优势明显。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天面试阿里被问到一个简单的多线程问题,脑子里第一个闪现的是wait()和notify(),写代码的时候又蹦出些其它想法,结果写的时间有点长,实现也有点混乱,回来后把当时的想法整理了一下,分别比较一下实现效率。

1.synchronized + wait +notify

这个实现可以看连接https://blog.youkuaiyun.com/woainiwss/article/details/52013810

2.condition + await + signal

private static ReentrantReadWriteLock lock = new ReentrantReadWriteLock();
private static Condition condition = lock.writeLock().newCondition();
private static final void runCount(Boolean ood) throws InterruptedException {
    for (int i = 0; i < 100001; i++) {
        lock.writeLock().lock();
        if(ood){
            if(i%2==1){
                //System.out.println(i);
                condition.await();
                continue;
            }else{
                condition.signal();
            }
        }else{
            if(i%2==0){
                //System.out.println(i);
                condition.await
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值