volatile关键字 Atomic类的使用示例

  1. volatile在只有一个线程写,但是存在多个线程读的时候使用,从而避免了使用synchronized,提高读写性能。
/**
 * valitile关键字
 *
 * @author xingguishuai
 * @create 2017-03-13-16:01
 **/
public class VolatileVariable extends Thread{

    private volatile Integer count = 0;
    public  void addCount(){
        System.out.println(Thread.currentThread().getName()+":count自增"+count++);
    }
    public  void run(){
        while (count < 3){
            //do nothing
        }
        //跳出循环结束,子线程结束
        System.out.println("count为"+count);
    }
    public static void main(String[] args) throws InterruptedException {
        //例1
        VolatileVariable volatileVariable = new VolatileVariable();
        //启动子线程,执行run方法
        volatileVariable.start();
        Thread.sleep(1000);
        volatileVariable.addCount();
        Thread.sleep(1000);
        volatileVariable.addCount();
        Thread.sleep(1000);
        volatileVariable.addCount();
}
  1. 当多个线程同时进行写操作时,不保证原子性,可以用atomic类来代替

例:

package com.fullstacker.study.course.concurrent;

import java.util.concurrent.atomic.AtomicInteger;

/**
 * Atomic类示例,多线程间保持原子性
 *
 *
 * @author xingguishuai
 * @create 2017-03-14-10:33
 **/
public class AtomicCount {
    private static AtomicInteger atomicInteger = new AtomicInteger(0);
    /**
    * <p>功能描述:</p>
     * t1,t2,t3三个线程修改atomicInteger,
     * 由于AtomicInteger在进行修改操作时会对值“加锁”,所以AtomicInteger可以保持原子性,
     * 所以在三条线程都进行完修改后,最后的结果为3000,但在三条线程未完全结束时,输出的数字
     * 不一定。
    * @return
    * @param
    * @author xingguishuai
    * @Date 2017-03-16 15:43
    * @since 1.0
    */
    public static void main(String[] args){

        Thread t1 = new Thread(new Runnable() {
            @Override
            public void run() {
                int count =0;
                while(count<1000){
                    atomicInteger.incrementAndGet();
                    count++;
                }
                System.out.println(Thread.currentThread().getName()+":"+atomicInteger.get());
            }
        },"t1");
        Thread t2 = new Thread(new Runnable() {
            @Override
            public void run() {
                int count =0;
                while(count<1000){
                    atomicInteger.incrementAndGet();
                    count++;
                }
                System.out.println(Thread.currentThread().getName()+":"+atomicInteger.get());
            }
        },"t2");
        Thread t3 = new Thread(new Runnable() {
            @Override
            public void run() {
                for(int count=0;count<1000;count++){
                    atomicInteger.incrementAndGet();
                }
                System.out.println(Thread.currentThread().getName()+":"+atomicInteger.get());
            }
        },"t3");
        t1.start();
        t2.start();
        t3.start();
    }
}

源码可参考我的GitHub项目:https://github.com/iqijun/javastudy/blob/ed901c2187e535b5d00e0f113baca2ef10099ef3/src/main/java/com/fullstacker/study/course/concurrent

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值