从头认识java-18.2 基本的线程机制(1)-再识多线程-2

接着上一个章节,我们这一章节介绍一下多线程的注意点。

线程间执行的顺序和时间是不同的

我们修改一下上一章节的代码:

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)