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

来源:互联网 发布:淘宝店铺旺旺名怎样看 编辑:程序博客网 时间:2024/05/20 06:36

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

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

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

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 + ") ";}@Overridepublic 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) 


总结:这一章节主要介绍了线程间执行顺序的问题。


这一章节就到这里,谢谢。

-----------------------------------

目录



0 0
原创粉丝点击