04 线程同步

问题

java中的线程同步机制是什么

答案

线程源自进程,是独立运行的基本单位,如果两个线程对同一个资源同时读写,那么这个资源就成了竞争性资源,此时必须提供同步机制,否则就会造成错误和混乱。例如,一个银行账号上有1000块钱,妻子在手机银行上消费了500块钱,丈夫在ATM机上取了500块钱,极有可能该银行账户上还有500块钱,实际上应该是0,如何避免这种情况,这就是线程同步机制解决的问题。java中的线程同步有以下几种方式:

  • 1 同步方法
    用synchronized修饰方法,则任何一个瞬间,只能有一个线程正在执行该方法,同一个对象的另一个线程调用该方法时将等待,直到前一个线程执行结束,释放内置锁,另一个线程才会正常执行。注意,内置锁是对象级别,也就是说不同对象的线程是可以进入到该方法的执行的,哪怕该方法正在被另一个对象的线程执行。除非,该方法在被synchronized修饰的同时,还被static修饰。
  • 2 同步代码块
    同步是一种高开销的操作,用synchronized修饰方法,锁的范围过大,消耗过大,因此应该减少同步的范围,同步代码块只需要同步需要同步的代码即可。
  • 3 volatile
    volatile是指令关键字,确保本条指令不会因编译器的优化而省略,保证了不同线程对这个变量进行操作时的可见性,即一个线程修改了某个变量的值,这新值对其他线程来说是立即可见的,但要注意,volatile 只能保证对单次读/写的原子性,例如对i++ 这种操作不能保证原子性。
  • 4 ReentrantLock
    ReentrantLock与synchronized修饰方法类似,只不过是手动获得锁以及释放锁,即创建一个ReentrantLock实例;获得锁;执行同步语句, 释放锁。
  • 5 使用JDK自带同步类或者接口
    HashTable、Vector、ConcurrentHashMap、Enumeration、StringBuffer、BlockingQueue等。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值