线程同步的方法

实现同步机制有两个方法 : 
1。同步代码块: 
synchronized(同一个数据){} 同一个数据:就是N条线程同时访问一个数据。 比如同一个数据可以是银行账号account,就是说同步监视器是account对象,它会经历加锁---》修改---》释放锁的历程
2。 
同步方法:无需显式的指定同步监视器,因为同步方法的监视器就是this,也就是对象本身。
public synchronized 数据返回类型 方法名(){} 
就是使用 synchronized 来修饰某个方法,则该方法称为同步方法。对于同步方法而言,无需显示指定同步监视器,同步方法的同步监视器是 this 也就是该对象的本身(这里指的对象本身有点含糊,其实就是调用该同步方法的对象)通过使用同步方法,可非常方便的将某类变成线程安全的类,具有如下特征: 
1,该类的对象可以被多个线程安全的访问。 
2,每个线程调用该对象的任意方法之后,都将得到正确的结果。 
3,每个线程调用该对象的任意方法之后,该对象状态依然保持合理状态。 
注:synchronized关键字可以修饰方法,也可以修饰代码块,但不能修饰构造器,属性等。 
实现同步机制注意以下几点: 安全性高,性能低,在多线程用。性能高,安全性低,在单线程用。 
1,不要对线程安全类的所有方法都进行同步,只对那些会改变共享资源方法的进行同步。 

2,如果可变类有两种运行环境,当线程环境和多线程环境则应该为该可变类提供两种版本:线程安全版本和线程不安全版本(没有同步方法和同步块)。在单线程中环境中,使用线程不安全版本以保证性能,在多线程中使用线程安全版本. 

那么什么时候会释放同步监视器的锁定

A当前线程的同步方法或者同步代码块执行完毕,当前线程即释放同步监视器

B同步方法或者同步块(下面简称为块和方法)碰到break、return终止了代码块或者该方法的执行时

C当前线程在方法和块中出现了未处理的Error或Exception,导致了该块或方法异常结束时

D程序执行了同步监视器的wait方法时,就是说wait方法会把锁给扔了

在以下几种情况不会释放同步监视器

A执行块或方法时,调用sleep()yield方法来暂停当前线程的执行时

B执行。。时用suspend将线程挂起,不会释放同步监视器。suspend和resume应该尽量避免使用


线程通讯 : 
为什么要使用线程通讯? 
当使用synchronized 来修饰某个共享资源时(分同步代码块和同步方法两种情况),当某个线程获得共享资源的锁后就可以执行相应的代码段,直到该线程运行完该代码段后才释放对该 共享资源的锁,让其他线程有机会执行对该共享资源的修改。当某个线程占有某个共享资源的锁时,如果另外一个线程也想获得这把锁运行就需要使用wait() 和notify()/notifyAll()方法来进行线程通讯了。 
Java.lang.object 里的三个方法wait() notify() notifyAll() 
wait方法导致当前线程等待,直到其他线程调用同步监视器的notify方法或notifyAll方法来唤醒该线程。 
wait(mills)方法 
都是等待指定时间后自动苏醒,调用wait方法的当前线程会释放该同步监视器的锁定,可以不用notify或notifyAll方法把它唤醒。 
notify() 
唤醒在同步监视器上等待的单个线程,如果所有线程都在同步监视器上等待,则会选择唤醒其中一个线程,选择是任意性的,只有当前线程放弃对该同步监视器的锁定后,也就是使用wait方法后,才可以执行被唤醒的线程。 
notifyAll()方法 

唤醒在同步监视器上等待的所有的线程。只用当前线程放弃对该同步监视器的锁定后,才可以执行被唤醒的线程


使用Condition控制线程通信

如果程序不使用synchronized关键字同步,而是用Lock对象来保证同步,则系统中不存在隐式的同步监视器,也就不能调用wait、notify和nofityAll三个方法了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值