class Callme {
void call(String msg) {
System.out.print("[" + msg);
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
System.out.println("Interrupted");
}
System.out.println("]");
}
}
class Caller implements Runnable {
String msg;
Callme target;
Thread t;
public Caller(Callme targ, String s) {
target = targ;
msg = s;
t = new Thread(this);
t.start();
}
public void run() {
//synchronized(target){ // synchronized block
target.call(msg);
//}
}
}
class Synch {
public static void main(String args[]) {
Callme target = new Callme();
Caller ob1 = new Caller(target, "Hello");
ob1.t.setPriority(Thread.NORM_PRIORITY);
Caller ob2 = new Caller(target, "Synchronized");
Caller ob3 = new Caller(target, "World");
ob2.t.setPriority(Thread.MAX_PRIORITY);
ob3.t.setPriority(Thread.MIN_PRIORITY);
System.out.println(ob1.t.getPriority());
System.out.println(ob2.t.getPriority());
System.out.println(ob3.t.getPriority());
// wait for threads to end
try {
ob1.t.wait();
ob2.t.wait();
ob3.t.wait();
ob1.t.notifyAll();
} catch(InterruptedException e) {
System.out.println("Interrupted");
}
}
}
В то время как мы отдаем приоритет дочерних потоки и wait()
и notifyall()
методов используются так должны работать в соответствии с приоритетом. Но не бегать. Если мы также используем synchronized(target)
, то также не запускаем в соответствии с приоритетом.ждать уведомит в Java
SIR ... КАК ВСЕ 3 РЕЗЬБЫ В ОЖИДАНИИ .... и после метода notifyall ... нить, у кого больше приоритета, будет работать первым или нет? –
Не существует уверенности в том, какой поток будет выполняться первым, но в целом более высокие потоки приоритетов имеют более высокую вероятность того, что они будут выбраны для выполнения в любой момент времени. – Attila
Правда, хотя он, вероятно, может реализовать свою собственную логику блокировки, чтобы иметь возможность уведомлять «хорошая» нить! –