package test;
public class SecondThread implements Runnable{
private int i;
public static void main(String[] args) {
// TODO Auto-generated method stub
for(int i=0; i<50; i++){
System.out.println(Thread.currentThread().getName() + " " + i);
if(i == 20){
SecondThread st = new SecondThread();
new Thread(st, "线程1").start();
new Thread(st, "线程2").start();
}
}
}
@Override
public void run() {
// TODO Auto-generated method stub
for(; i<10; i++){
System.out.println(Thread.currentThread().getName() + " " + i);
}
}
}
代码如上(来自《疯狂java讲义》),看书中介绍说这里两个线程是会共享SecondThread 的变量i的,可是我运行后却看到了奇怪的结果:
奇怪之处1:为啥结果里会有:“线程1 1”和“线程2 1”呢?两个线程不是共享了变量i吗?
奇怪之处2:为啥结果里两个线程后面跟的i不是递增呢?
变量是共享的,但是你对变量的修改并非是线程安全的,所以说可能会出现你在A线程中打印i时,还没有进行对i的增加时,在B线程中就又进行了i的打印。因为没有进行线程同步的操作,所以出现的结果时无法预期的。
没有递增原因也是多个线程同时写入输出缓冲区,没有进行线程安全的操作,在组织输出字符串到真正输出到缓冲区之间,被其他线程插队的现象是可能出现的。