@Override
public void run() {
while (count > 1) {
cal();
}
}
private synchronized void cal() {
try {
Thread.sleep(10);
} catch (Exception e) {
}
count--;
System.out.println(Thread.currentThread().getName() + "," + count);
}
public static void main(String[] args) {
ThreadCount threadCount = new ThreadCount();
Thread thread1 = new Thread(threadCount);
Thread thread2 = new Thread(threadCount);
thread1.start();
thread2.start();
}
synchronized在方法上锁this , new Thread(threadCount); 是两个不同的对象了 ,他是怎么锁住的??
chatgpt:
虽然创建了两个线程对象 thread1 和 thread2,但是它们都共享同一个 ThreadCount 实例 threadCount,因为 ThreadCount 类实现了 Runnable 接口,所以 thread1 和 thread2 都是基于同一个 Runnable 对象 threadCount 启动的。
因此,当 cal() 方法被调用时,它是在同一个实例上同步的,即它们都在同一个对象上调用方法,并共享同一个锁。
由于 cal() 方法被声明为 private synchronized,所以只有一个线程能够访问该方法。因此,在每个线程调用 cal() 方法时,它会获得 ThreadCount 实例的锁,以便其他线程不能同时访问该方法,直到该方法执行完毕并释放锁为止。
因此,使用 synchronized 在方法上锁住的是实例对象,而不是类或线程对象。在这种情况下,两个线程共享同一个实例对象,并通过该对象上的锁来同步它们的访问。