标签:
接着上一个章节,我们这一章节介绍一下多线程的注意点。
线程间执行的顺序和时间是不同的
我们修改一下上一章节的代码:
package com.ray.ch17; public class Test { public static void main(String[] args) { for (int i = 5; i < 8; i++) { DoneMission doneMission = new DoneMission(i); Thread thread = new Thread(doneMission); thread.start(); } System.out.println("working"); } } class DoneMission implements Runnable { private final int id = index++; private int count = 0; private static int index = 0; public DoneMission(int count) { this.count = count; } public String leftMission() { return "#" + id + "(" + count + ") "; } @Override public void run() { while (count-- > 0) { System.out.print(leftMission()); Thread.yield(); } } }
working
#0(4) #2(6) #1(5) #2(5) #2(4) #2(3) #2(2) #2(1) #1(4) #1(3) #1(2) #2(0) #1(1) #1(0) #0(3) #0(2) #0(1) #0(0)
从输出可以看见,main方法的线程跟我们启动的线程在执行上面不按照既定的顺序来的。
如果我们再多运行几次,我们还可以看见后面的运行的结果的顺序也是不一样的:
working
#2(6) #0(4) #0(3) #0(2) #0(1) #0(0) #2(5) #1(5) #2(4) #1(4) #2(3) #1(3) #1(2) #2(2) #2(1) #1(1) #2(0) #1(0)
working
#1(5) #1(4) #1(3) #1(2) #1(1) #1(0) #2(6) #2(5) #2(4) #2(3) #2(2) #0(4) #0(3) #0(2) #0(1) #2(1) #2(0) #0(0)
总结:这一章节主要介绍了线程间执行顺序的问题。
这一章节就到这里,谢谢。
-----------------------------------
从头认识java-17.2 基本的线程机制(1)-初识多线程-2
标签:
原文地址:http://blog.csdn.net/raylee2007/article/details/50481847