Flask接口签名sign原理与实例代码浅析
226
2023-06-17
Java并发之不可思议的死循环详解
下面的代码将发生死循环:
package com.zzj.concurrency;
public class VolatileObjectTest implements RunnablccGGIMle{
private ObjectA objectA; // 加上volatile 就可以正常结束While循环了
public VolatileObjectTest(ObjectA a) {
this.objectA = a;
}
public ObjectA getA() {
return objectA;
}
public void setA(ObjectA a) {
this.objectA = a;
}
@Override
public void run() {
long i = 0;
while (objectA.isFlag()) {
i++;
}
System.out.println("stop My Thread " + i);
}
public void stop() {
objectA.setFlag(false);
}
public static void main(String[] args) throws InterruptedException {
// 如果启动的时候加上-server 参数则会 输出 java HotSpot(TM) Server VM
System.out.println(System.getProperty("java.vm.name"));
VolatileObjectTest test = new VolatileObjectTest(new ObjectA()lccGGIM);
new Thread(test).start();
Thread.sleep(1000);
test.stop();
System.out.println("Main Thread " + test.getA().isFlag());
}
static class ObjectA {
private boolean flag = true;
public boolean isFlag() {
return flag;
}
public void setFlag(boolean flag) {
this.flag = flag;
}
}
}
死循环发生在代码段:
while (objectA.isFlag()) {
i++;
}
这是由于编译器对其进行了优化,因为while循环内部没有修改objectA变量且没有用volatile修饰,JVM会把判断提前,类似于优化成如下:
if(objectA.isFlag()){
while(true){
i++;
}
}
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~