我正在尝试了解同步方法的工作原理。根据我的理解,我创建了两个线程 T1 和 T2,它们将调用相同的方法 addNew
,因为该方法是同步的,它不应该执行所有一个线程的 for 循环迭代,然后是另一个?输出不断变化,有时打印正确,有时打印来自 T1 的值与 T2 值的混合。代码很简单,有人能指出我做错了什么吗?谢谢。
public class Main {
public static void main(String[] args) {
Thread t1 = new Thread(new A());
Thread t2 = new Thread(new A());
t1.setName("T1");
t2.setName("T2");
t1.start();
t2.start();
}
}
public class B {
public synchronized void addNew(int i){
Thread t = Thread.currentThread();
for (int j = 0; j < 5; j++) {
System.out.println(t.getName() +"-"+(j+i));
}
}
}
public class A extends Thread {
private B b1 = new B();
@Override
public void run() {
b1.addNew(100);
}
}
最佳答案
每个A
实例都有自己的B
实例。方法addNew
是B
的实例方法。因此,在调用 addNew
期间隐式获取的锁是接收器 B
实例上的锁。每个线程都在不同的 B
上调用 addNew
,因此锁定在不同的锁上。
如果您希望所有 B
实例使用一个公共(public)锁,创建一个共享锁,并在addNew
的主体中获取它.
关于java - 为什么 Java synchronized 没有按预期工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44205710/