zoukankan      html  css  js  c++  java
  • 测试AtomicInteger的可见性、有序性、原子性

    package com.dwz.atomic;
    
    import java.util.Collections;
    import java.util.HashSet;
    import java.util.Set;
    import java.util.concurrent.atomic.AtomicInteger;
    /**
     * AtomicInteger
     * 可见性
     * 有序性
     * 原子性
     */
    public class AtomicIntegerTest {
        public static void main(String[] args) throws InterruptedException {
            Set<Integer> set = Collections.synchronizedSet(new HashSet<Integer>());
            AtomicInteger value = new AtomicInteger();
            Thread t1 = new Thread() {
                @Override
                public void run() {
                    int x = 0;
                    while(x < 500) {
                        int v = value.getAndIncrement();
                        set.add(v);
                        System.out.println(Thread.currentThread().getName() + ":" + v);
                        x++;
                    }
                }
            };
            
            Thread t2 = new Thread() {
                @Override
                public void run() {
                    int x = 0;
                    while(x < 500) {
                        int v = value.getAndIncrement();
                        set.add(v);
                        System.out.println(Thread.currentThread().getName() + ":" + v);
                        x++;
                    }
                }
            };
            
            Thread t3 = new Thread() {
                @Override
                public void run() {
                    int x = 0;
                    while(x < 500) {
                        int v = value.getAndIncrement();
                        set.add(v);
                        System.out.println(Thread.currentThread().getName() + ":" + v);
                        x++;
                    }
                }
            };
            
            t1.start();
            t2.start();
            t3.start();
            
            t1.join();
            t2.join();
            t3.join();
            
            System.out.println(set.size());
        }
    }

     总结:

    1.volatile修饰的变量可以保证可见性和有序性
    2.CAS算法,也就是CPU级别的同步指令,相当于乐观锁,它可以测到其他线程对共享数据的变化情况

  • 相关阅读:
    07-图4 哈利·波特的考试 (25分)
    Windows环境下清除SVN文件
    查看SQL SERVER 2008R2 表大小
    Oauth支持的5类 grant_type 及说明
    SignalR的性能监测
    Loadrunner11安装
    Azure ServiceBus 通信失败问题
    sql server text类型 存储问题
    System.BadImageFormatException
    InputStream只能读取一次的解决办法 C# byte[] 和Stream转换
  • 原文地址:https://www.cnblogs.com/zheaven/p/12981777.html
Copyright © 2011-2022 走看看