接着上一个章节,我们这一章节介绍一下多线程的注意点。
线程间执行的顺序和时间是不同的
我们修改一下上一章节的代码:
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)
总结:这一章节主要介绍了线程间执行顺序的问题。
这一章节就到这里,谢谢。
-----------------------------------