我在同一个文件中有以下程序。我已经同步了run()方法。
class MyThread2 implements Runnable {
Thread t;
MyThread2(String s) {
t=new Thread(this,s);
t.start();
}
public synchronized void run() {
for (int i=0;i<3;i++) {
System.out.println("Thread name : "+ Thread.currentThread).getName());
try {
t.sleep(1000);
}
catch (InterruptedException e) {
e.getMessage();
}
}
}
}
class TestSync {
public static void main(String[] args) {
MyThread2 m1=new MyThread2("My Thread 1");
c.fun();
}
}
class c {
static void fun() {
MyThread2 m1=new MyThread2("My Thread 4");
}
}
输出
Thread name : My Thread 1
Thread name : My Thread 4
Thread name : My Thread 4
Thread name : My Thread 1
Thread name : My Thread 1
Thread name : My Thread 4
我的问题是为什么同步方法同时允许“My Thread 1”和“My Thread 4”线程访问?
答案 0 :(得分:30)
synchronized
方法在实例级别工作。该类的每个实例都有自己的锁。每次输入实例的synchronized
方法时,都会获取锁。这可以防止多个线程在同一个实例上调用synchronized
个方法 (请注意,这也会阻止不同的 synchronized
方法在同一个实例上调用
现在,由于您的类有两个实例,因此每个实例都有自己的锁。没有什么可以阻止两个线程同时在它自己的实例上运行。
如果你想阻止这种情况,你可以在synchronized(obj)
内设置一个run()
块,其中obj
将是你班级的两个实例共享的某个对象:
class MyThread2 implements Runnable {
private static final Object lock = new Object();
...
public void run() {
synchronized(lock) {
...
}
}
}