- synchronized互斥锁
* 当synchronized将不同的代码片段修改后,只要
* 锁对象相同,那么这些代码是互斥的,多个线程不能
* 同时进到这些不同方法中
下面通过简单实例演示:
没有加锁的情况:
public class SyncDemo4 { public static void main(String[] args) { final Foo foo = new Foo(); Thread t1 = new Thread(){ @Override public void run() { foo.methodA(); } }; Thread t2 = new Thread(){ @Override public void run() { foo.methodB(); } }; t1.start(); t2.start(); } } class Foo{ public void methodA(){ Thread t = Thread.currentThread(); System.out.println(t.getName()+"正在运行methodA方法"); try { Thread.sleep(5000); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println(t.getName()+"运行methodA方法完毕"); } public void methodB(){ Thread t = Thread.currentThread(); System.out.println(t.getName()+"正在运行methodB方法"); try { Thread.sleep(5000); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println(t.getName()+"运行methodB方法完毕"); } }
运行程序控制台输出:可以看到线程1在执行B方法时 线程0也可以执行同一对象另一A方法。没有达到互斥的作用。
如何实现一个线程在执行同一对象的一个方法时,另一个线程就不能调用同一对象的另一个方法,即互斥锁效果
我们只要使用synchronized分别对同一对象的需要互斥的方法加锁即可:
加锁后代码如下所示:
public class SyncDemo4 { public static void main(String[] args) { final Foo foo = new Foo(); Thread t1 = new Thread(){ @Override public void run() { foo.methodA(); } }; Thread t2 = new Thread(){ @Override public void run() { foo.methodB(); } }; Thread t3 = new Thread(){ @Override public void run() { foo.methodC(); } }; t1.start(); t2.start(); t3.start(); } } class Foo{ public synchronized void methodA(){ Thread t = Thread.currentThread(); System.out.println(t.getName()+"正在运行methodA方法"); try { Thread.sleep(5000); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println(t.getName()+"运行methodA方法完毕"); } public synchronized void methodB(){ Thread t = Thread.currentThread(); System.out.println(t.getName()+"正在运行methodB方法"); try { Thread.sleep(5000); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println(t.getName()+"运行methodB方法完毕"); } public void methodC(){ Thread t = Thread.currentThread(); System.out.println(t.getName()+"正在运行methodC方法"); try { Thread.sleep(5000); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println(t.getName()+"运行methodC方法完毕"); } }
再次运行程序后控制台输出:我们发现加锁后的A方法与B方法已经产生互斥,而没有加锁的C方法不受A方法与B方法加锁的影响,
没有互斥的效果。
扫描二维码关注公众号,回复:
1439324 查看本文章
总结:对想实现互斥锁的方法,只要将对应类的成员方法加锁即可。
不同线程在调用同一对象不同方法时才会有互斥锁效果