java - 这段代码中线程的执行顺序?
本文介绍了java - 这段代码中线程的执行顺序?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
问 题
package thread.name;
import java.text.SimpleDateFormat;
import java.util.Date;
public class GetThreadName implements Runnable {
//private int i=10;
private boolean flag = true;
@Override
public void run() {
while(flag){
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName());
System.out.println("================");
}
}
public void stop(){
this.flag = false;
}
}
public class ThreadMain {
/**
* @param args
* @throws InterruptedException
*/
public static void main(String[] args) throws InterruptedException {
// TODO Auto-generated method stub
GetThreadName test = new GetThreadName();
Thread proxy1 = new Thread(test,"test1");
proxy1.start();
System.out.println(Thread.currentThread().getName()+"-proxy1-");
System.out.println("====================");
System.out.println(Thread.currentThread().getName()+"-main-");
System.out.println("====================");
test.stop();
System.out.println(Thread.currentThread().getName());
}
}
为什么输出是
main-proxy1-
====================
main-main-
====================
main
test1
================
这段代码中线程的执行顺序是? 为什么最后一个main出现在test1 上面?
解决方案
test1线程开始睡,main线程打印:
main-proxy1-
====================
main-main-
====================
main线程设置flag=false后test1线程还没醒,只有main一个可运行线程,main线程打印:
main
main线程结束
3秒之后test1线程睡醒了,打印:
test1
================
第二次循环flag为false跳出循环,test1线程结束
另外这种情况下flag应该用volatile修饰保证可见性。
这篇关于java - 这段代码中线程的执行顺序?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文