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

查看:113
本文介绍了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屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆