Java并发之不可思议的死循环详解

网友投稿 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小时内删除侵权内容。

上一篇:MyBatis实现物理分页的实例
下一篇:java利用时间格式生成唯一文件名的方法
相关文章

 发表评论

暂时没有评论,来抢沙发吧~