码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2016-01-08 14:38:12      阅读:155      评论:0      收藏:0      [点我收藏+]

标签:

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

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

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

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!