public class Machine extends Thread {
	private int a = 0; // 实例变量
	
	public void run() {
		for(a = 0; a < 50; a++) { // 使用Machine对象的实例变量a
			System.out.println(currentThread().getName() + ":" + a);
				try {
					sleep(100); // 给其他线程运行的机会
				} catch (InterruptedException e) {
					throw new RuntimeException(e);
				}
		}
	}
	
	public static void main(String[] args) {
		Machine m1 = new Machine();
		m1.start(); // 启动第一个Machine线程
		m1.run();   // 主线程执行第一个Machine对象的run()方法
	}
}



运行程序,查看结果: 


main:0
Thread-0:0
main:1
Thread-0:2
...
main:21
Thread-0:21
...


 首先理解下为什么会出现main:0和Thread-0:0


 m1.run():刚开始调用这个方法的时候,会给a赋初值,a=0

 m1.start():刚开始调用这个线程的时候,也会给a赋初值a=0

 其实就是每次调用run()方法的时候  for(a = 0; a < 50; a++){}都会给变量a赋一次初值0




而运行过程中还会出现下面的情况:

main:21

Thread-0:21

 既然主线程和Machine线程共享实例变量a,轮流将a的值加上1,怎么还会出现两个线程出现想等的值呢?


下面用张示意图,大致画了一下可能会出现的位置


线程共享实例变量
 

这个时候Machine线程所打印出来的变量a的值正好和主线程运行时变量a的值相等


 

相关文章: