public class DualSynch {
private Object syncObject = new Object();
public synchronized void f() {
for(int i = 0; i < 5; i++) {
Print.print("f()");
//Thread.yield();
}
}
public void g() {
synchronized(syncObject) {
for(int i = 0; i < 5; i++) {
Print.print("g()");
//Thread.yield();
}
}
}
}
public class SyncObject {
public static void main(String[] args) {
final DualSynch ds = new DualSynch();
new Thread() {
public void run() {
ds.f();
}
}.start();
ds.g();
}
}
另外,Thread.yield()在这里起什么作用?
经过运行发现,f()和g()在两个线程中交替执行,而加上Thread.yield()之后则会先执行完其中一个线程的方法,再执行另一个线程的方法。
但我对这个同步机制不是特别理解
这两个线程根本就没有进行同步,对于d2.f()是在新创建的线程中运行的,它所获得的同步锁是ds对象的同步锁,而ds.g()是在主线程中运行的,它所获得
同步锁是synObject对象。两个线程持有的同步锁不同,所以起不了同步作用。
关于Thread的yield方法,它是让线程释放当前cpu但是不释放同步锁,然后该线程进入就绪状态。然后让相同优先级进程可以获得执行的机会,但是这并不能保证其它同步优先级的线程获得执行机会,之前调用yield方法的线程也可以被cpu调度。