Java多线程入门级小问题

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的,可是我运行后却看到了奇怪的结果:

clipboard.png
奇怪之处1:为啥结果里会有:“线程1 1”和“线程2 1”呢?两个线程不是共享了变量i吗?
奇怪之处2:为啥结果里两个线程后面跟的i不是递增呢?

阅读 2.4k
1 个回答

变量是共享的,但是你对变量的修改并非是线程安全的,所以说可能会出现你在A线程中打印i时,还没有进行对i的增加时,在B线程中就又进行了i的打印。因为没有进行线程同步的操作,所以出现的结果时无法预期的。
没有递增原因也是多个线程同时写入输出缓冲区,没有进行线程安全的操作,在组织输出字符串到真正输出到缓冲区之间,被其他线程插队的现象是可能出现的。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题