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的值相等