JAVA 同步之 synchronized 修饰方法
2015-07-26 21:32
141 查看
在JAVA多线程编程中,将需要并发执行的代码放在Thread类的run方法里面,然后创建多个Thread类的对象,调用start()方法,线程启动执行。
当某段代码需要互斥时,可以用 synchronized 关键字修饰,这里讨论 synchronized 关键字修饰方法时,是如何互斥的。
synchronized 修饰方法时锁定的是调用该方法的对象。它并不能使调用该方法的多个对象在执行顺序上互斥。
下面举个具体的例子说明:
Test.java 通过 implements Runnable 成为一个线程类,它有一个MethodSync实例变量,这样,每当实例化一个Test对象时(相当于创建一个线程)就会初始化一个相应的MethodSync对象。然后在Test类的run()方法里面调用 synchronized 修饰的方法。
Test.java
上面创建了二个Test类的对象,相当于启动了两个线程, 这两个线程将会并发地执行它们的run方法中的代码。
MethodSync.java ,该类只拥有一个用来测试的 synchronized 方法
先看执行结果:
test1 先于 test2 执行 同步方法,但是却后于 test2 结束。这里并没有达到互斥的效果!原因是:MethodSync是实例变量,每次创建一个Test对象就会创建一个MethodSync对象, synchronized 只会锁定调用method()方法的那个MethodSync对象,而这里创建的两个线程分别拥有两个不同的MethodSync对象,它们调用method方法时就没有互斥关系。
当把Test.java 中的MethodSync 变量 用 static 来修饰时,执行结果如下:
这里,正确实现了同步作用。原因如下:这里也创建了二个线程(Test 对象),但是每个Test对象共享MethodSync 变量,也即只有一个MethodSync 变量在两个线程中执行 method方法,这样两个线程在执行到method 方法这段代码时就会形成互斥。
当某段代码需要互斥时,可以用 synchronized 关键字修饰,这里讨论 synchronized 关键字修饰方法时,是如何互斥的。
synchronized 修饰方法时锁定的是调用该方法的对象。它并不能使调用该方法的多个对象在执行顺序上互斥。
下面举个具体的例子说明:
Test.java 通过 implements Runnable 成为一个线程类,它有一个MethodSync实例变量,这样,每当实例化一个Test对象时(相当于创建一个线程)就会初始化一个相应的MethodSync对象。然后在Test类的run()方法里面调用 synchronized 修饰的方法。
Test.java
public class Test implements Runnable{ private String name; // private static MethodSync methodSync = new MethodSync(); private MethodSync methodSync = new MethodSync(); public Test(String name){ this.name = name; } @Override public void run() { methodSync.method(name); } public static void main(String[] args) { Thread t1 = new Thread(new Test("test 1")); Thread t2 = new Thread(new Test("test 2")); t1.start(); t2.start(); } }
上面创建了二个Test类的对象,相当于启动了两个线程, 这两个线程将会并发地执行它们的run方法中的代码。
MethodSync.java ,该类只拥有一个用来测试的 synchronized 方法
public class MethodSync { /* * @Task : 测试 synchronized 修饰方法时锁定的是调用该方法的对象 * @param name 线程的标记名称 */ public synchronized void method(String name){ System.out.println(name + " Start a sync method"); try{ Thread.sleep(300); }catch(InterruptedException e){} System.out.println(name + " End the sync method"); } }
先看执行结果:
test1 先于 test2 执行 同步方法,但是却后于 test2 结束。这里并没有达到互斥的效果!原因是:MethodSync是实例变量,每次创建一个Test对象就会创建一个MethodSync对象, synchronized 只会锁定调用method()方法的那个MethodSync对象,而这里创建的两个线程分别拥有两个不同的MethodSync对象,它们调用method方法时就没有互斥关系。
当把Test.java 中的MethodSync 变量 用 static 来修饰时,执行结果如下:
这里,正确实现了同步作用。原因如下:这里也创建了二个线程(Test 对象),但是每个Test对象共享MethodSync 变量,也即只有一个MethodSync 变量在两个线程中执行 method方法,这样两个线程在执行到method 方法这段代码时就会形成互斥。
相关文章推荐
- Java文件拷贝
- java之连续子数组的最大和
- hihocoder 1154 Spring Outing
- 希尔排序与堆排序(Java版)
- 初学JavaWeb开发遇到的问题与解决
- Java IO(三) 之 FileInputStream
- java:带有图形化界面,可以发送和接收的聊天工具
- java实现冒泡排序
- MyEclipse快捷键大全
- java实现选择排序
- 栈和队列常见题型(java版)
- 文本文件BASE-64编码解码
- 深入理解java垃圾回收机制
- JavaEE总论
- 学习 java netty (一) -- java nio
- 冒泡,简单选择,直接插入排序(Java版)
- java 获取局域网中的所有主机名和IP地址
- JDK 8 中Interface新增的default方法和static方法的区别和使用
- Java读写文件中文乱码问题折腾一个周末重要解决
- Java小日历