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级别的同步指令,相当于乐观锁,它可以测到其他线程对共享数据的变化情况

  • 相关阅读:
    Android RSS阅读器
    X86汇编语言学习教程之1 ————前言
    beanstalk源码剖析——概述
    从软件质量看如何写代码(1)
    软件开发模型
    软件质量思考
    数据结构概述
    Don't Distract New Programmers with OOP(转)
    Linus Torvalds’s Lessons on Software Development Management(转)
    谈测试驱动开发
  • 原文地址:https://www.cnblogs.com/zheaven/p/12981777.html
Copyright © 2011-2022 走看看