Java 多线程 --- 线程同步与线程协作的区别


背景: 操作系统 — 线程/进程 同步

线程同步

  • 线程同步解决的是race condition问题, 也就是保证了线程安全, 让多个线程可以并发访问共享资源

Java中的线程同步机制包括

  • ReentrantLock (使用锁)
  • synchronized关键字 (使用锁)
  • volatile关键字
  • Java 原子变量类 (Atomics): java.util.concurrent.atomic
  • 线程安全的集合: ConcurrentHashMap<K,V> , ConcurrentLinkedDeque<E>, ConcurrentLinkedQueue<E>

使用提示:

  • 遇到线程同步的问题时, 首先使用 java.util.concurrent pakcage, (不包括java.util.concurrent.locks) 主要指 atomics类ConcurrentHashMap, ConcurrentLinkedDeque, ConcurrentLinkedQueue. 这些都是封装好的线程安全的库
  • 如果不能满足需求, 则选择使用synchronized, volatile.
  • 实在不行再用 java.util.concurrent.locks 包括 ReentrantLock

线程协作

  • 线程协作是指多个线程分工合作, 共同完成任务.
  • 比如线程的互相唤起, 阻塞, 中断等都是线程协作

Java中的线程协作机制包括

  • 等待与通知: Object.wait/notify
  • Condition变量: java.util.concurrent.locks.Condition
  • 倒计时协调器(CountDownLatch): java.util.concurrent.locks.CountDownLatch
  • 栅栏:(CycliBarrier): java.util.concurrent.locks.CyclicBarrier
  • 生产者消费者模式
  • 线程中断机制(Interrupt)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值