首页 > Java多线程入门级小问题

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


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


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

【热门文章】
【热门文章】