为了账号安全,请及时绑定邮箱和手机立即绑定

这段代码中线程的执行顺序?

这段代码中线程的执行顺序?

汪汪一只猫 2019-03-12 13:15:11
package thread.name;import java.text.SimpleDateFormat;import java.util.Date;public class GetThreadName implements Runnable {//private int i=10;private boolean flag = true;@Overridepublic 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-====================maintest1================这段代码中线程的执行顺序是? 为什么最后一个main出现在test1 上面?
查看完整描述

3 回答

?
波斯汪

TA贡献1811条经验 获得超4个赞

test1线程开始睡,main线程打印:


main-proxy1-

====================

main-main-

====================

main线程设置flag=false后test1线程还没醒,只有main一个可运行线程,main线程打印:


main

main线程结束

3秒之后test1线程睡醒了,打印:


test1

================

第二次循环flag为false跳出循环,test1线程结束


另外这种情况下flag应该用volatile修饰保证可见性。


查看完整回答
反对 回复 2019-04-18
?
素胚勾勒不出你

TA贡献1827条经验 获得超9个赞

因为Main线程中的代码很快就执行完了,而test1至少需要sleep 3秒,然后才能打印。另外这种情况下flag应该用volatile修饰保证可见性。


查看完整回答
反对 回复 2019-04-18
?
胡说叔叔

TA贡献1804条经验 获得超8个赞

Thread.sleep(3000);本来是并行的,加了这个,当然是main先执行完。最后输出的是test1


查看完整回答
反对 回复 2019-04-18
  • 3 回答
  • 0 关注
  • 516 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信