Java并发计数器多1

在学习并发。尝试做一个计数器。 然后不知道为什么有时候计数会多1.有时候又不会。请问要怎样才能完成正确的计数。

public class IncrementTest {

    static class Counter {
        private AtomicInteger count = new AtomicInteger();

        public void increment() {
            count.incrementAndGet();
        }
        public int getCount() {
            return count.get();
        }
    }

    static Counter c = new Counter();

    static class Test implements Runnable{
        public void run() {
            while (c.getCount() < 100){
                c.increment();
            }
            System.out.println(Thread.currentThread().getName()  + ":" + c.getCount());
        }
    }

    public static void main(String[] args) {
        Test t = new Test();
        Thread test = new Thread(t);
        test.start();

        Test t2 = new Test();
        Thread test2 = new Thread(t2);
        test2.start();

    }
}

修改后的部分

 private static AtomicInteger count = new AtomicInteger();

    static class Test implements Runnable{
        public  void run() {
            while (count.incrementAndGet() < 10000){}
            System.out.println(Thread.currentThread().getName()  + ":" + count);
        }
    }

但是这样子最后一个结果会多1 ....

阅读 5.2k
3 个回答

你同步跟原子性搞混了吧,static class Test implements Runnable{

    public void run() {
        while (c.getCount() < 100){
            c.increment(); -----》①
        }
        System.out.println(Thread.currentThread().getName()  + ":" + c.getCount());
    }
}这段代码出的问题,可能存在:当count为99时,A线程执行到①时(还没进行自增),线程调度器切换到B线程,这是B读取的count还是99,然后进行自增。说错了的话请指教

建议使用AtomicInteger 的 incrementAndGet方法
因为,如果两个线程同时执行到while (c.getCount() < 100)的时候,就会出现最后两个线程都执行了+1的操作。
使用incrementAndGet可以保证increse和get两个操作的线程安全

同意楼上的说法

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