gpt4 book ai didi

java - 在另一个 Synchronized 中调用 Synchronized

转载 作者:行者123 更新时间:2023-11-29 09:43:31 27 4
gpt4 key购买 nike

第 1 部分:

假设下面这段代码

void method1(){

synchronized (lockObject){
method2();
System.out.println("line4");
}

}

void method2(){
System.out.println("line1");

synchronized (lockObject){
System.out.println("line2");
}

System.out.println("line3");
}

这是死锁吗?这是一个安全的代码吗?输出是否总是:

line1
line2
line3
line4

第 2 部分:

如果 method2() 在另一个线程上执行怎么办?输出会不同吗?像这样:

void method1(){

synchronized (lockObject){
method2();
System.out.println("line4");
}

}

void method2(){
newThread= new Thread(new Runnable() {
@Override
public void run() {
System.out.println("line1");
synchronized (lockObject){
System.out.println("line2");
}
System.out.println("line3");
}
}).start();
}

我猜这第二个代码的输出可能是:

line4
line1
line2
line3

这是正确的吗?

最佳答案

是的,您可以在同一个对象上多次同步而不会出现死锁,它的工作方式类似于可重入锁。

至于输出。第一种是简单的顺序输出,同步不影响。第二个线程将产生预期的输出,因为另一个线程必须等待第一个线程释放 lockObject。

编辑,line1 和 line4 的顺序未确定,因为之前没有同步。 line2 和 line3 总是在 line4 之后,因为第二个线程在第一个线程离开 method1 同步块(synchronized block)之前无法开始打印 line1。

关于java - 在另一个 Synchronized 中调用 Synchronized,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29153330/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com