您的位置:首页 > 编程语言 > Java开发

简单安全高效的Java计数器

2017-05-27 14:21 288 查看
本文利用AtomicLong实现了一个安全高效的计数器,利用线程池技术,测试结果符合预期,避免了线程并发操作变量问题,避免使用同步锁提高了效率。

package com.springapp.mvc;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.atomic.AtomicLong;

/**
* Created by acer on 2017/5/27.
*/
public class TestAtomic {
//AtomicLong 的api参考 http://www.tuicool.com/articles/uY3qIbB public static final AtomicLong atomicLong = new AtomicLong(0L);

public static void main(String[] args) {
ExecutorService executorService = Executors.newFixedThreadPool(10);
MyThread myThread = null;
for(int i = 0;i<100;i++){
myThread = new MyThread(atomicLong);
//ExecutorService的api中文解释【启动一次顺序关闭,执行以前提交的任务,但不接受新任务】 http://tool.oschina.net/apidocs/apidoc?api=jdk-zh executorService.submit(myThread);
}
executorService.shutdown();
System.out.println(atomicLong.get());
}
}

class MyThread extends Thread {
private AtomicLong atomicLong;

public MyThread(AtomicLong atomicLong){
this.atomicLong = atomicLong;
}

@Override
public void run() {
System.out.println(Thread.currentThread().getName() + "正在执行。。。");
System.out.println(atomicLong.incrementAndGet());
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  java 线程池 并发 线程