синхронизированное ключевое слово в нестатических методах означает точно синхронизировать меня для этих методов: эти два кода являются строгим эквивалентом:
public synchronised void dojob(){
//the job to do
}
et
public void dojob(){
synchronised (this){
//the job to do
}
}
в вашем случае ваши синхронизированные методы синхронизируются на разных объектах (t1, t2, t3 и t4), поэтому не блокировали их друг друга. лучшее решение заключается в том, что ваш поток будет использовать общий объект для синхронизации друг с другом. другой момент, лучше всегда вернуть поток, чтобы выполнить этот вызов join, это код, который делает то, что вы хотите с этими 2 исправлениями
class MyThread implements Runnable {
public static class JobDoer {
public synchronized void syncMethod() throws InterruptedException {
for (int i = 0; i < 100000; i++) {
System.out.println(Thread.currentThread().getName() + " : " + counter++);
}
}
}
private static int counter = 1;
public MyThread(JobDoer doer) {
this.doer = doer;
}
private JobDoer doer;
@Override
public void run() {
try {
doer.syncMethod();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
public static void main(String[] args) throws InterruptedException {
JobDoer doer = new JobDoer();
Thread t1 = new Thread(new MyThread(doer), "Thread 1");
Thread t2 = new Thread(new MyThread(doer), "Thread 2");
Thread t3 = new Thread(new MyThread(doer), "Thread 3");
Thread t4 = new Thread(new MyThread(doer), "Thread 4");
t2.start();
t1.start();
t3.start();
t4.start();
t1.join();
t2.join();
t3.join();
t4.join();
}
}