/**
* 对象锁的同步和异步问题
* @author gb
*/
public class ObjectLockSyn {
public synchronized void method1(){
try {
System.out.println(Thread.currentThread().getName());
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
/** synchronized */
public void method2(){
System.out.println(Thread.currentThread().getName());
}
public static void main(String[] args) {
final MyObject mo = new MyObject();
/**
* 分析:
* t1线程先持有object对象的Lock锁,t2线程可以以异步的方式调用对象中的非synchronized修饰的方法
* t1线程先持有object对象的Lock锁,t2线程如果在这个时候调用对象中的同步(synchronized)方法则需等待,也就是同步
*/
Thread t1 = new Thread(new Runnable() {
@Override
public void run() {
mo.method1();
}
},"t1");
Thread t2 = new Thread(new Runnable() {
@Override
public void run() {
mo.method2();
}
},"t2");
t1.start();
t2.start();
}
}
本文通过一个具体的Java代码示例,深入探讨了对象锁的同步和异步特性。演示了当一个线程持有对象锁时,另一个线程如何能够异步调用该对象的非synchronized方法,以及当尝试调用同步方法时所需等待的情况,从而清晰地解释了对象锁的同步机制。
866

被折叠的 条评论
为什么被折叠?



