黑马程序员-java5原子性操作类的应用

来源:互联网 发布:紫光存储芯片 知乎 编辑:程序博客网 时间:2024/05/16 14:06

---------------------- <a href="http://www.itheima.com"target="blank">ASP.Net+Unity开发</a>、<a href="http://www.itheima.com"target="blank">.Net培训</a>、期待与您交流! ----------------------

1、Java.util.concurrent.atomic

列如:AtomicInteger,多个线程要对共享变量count进行操作(改变值得操作,+-),这个count就可以定义为AtomicInteger类型,在这个类里面有addAndGet(int delta)实现对count的加减操作,decrementAndGet()实现对count1操作,incrementAndGet()实现对count减一。

 还有AtomicIntegerArray,addAndGet(int i,int delta)以原子方式将给定值与索引i的元素相加,还有incrementAndGet(i),decrementAndGet(i)等。、

AtomicIntegerFieldupdater<T>

 

 

2、线程池

线程池与Executors类的应用

import java.util.concurrent.ExecutorService;import java.util.concurrent.Executors;public class ThreadPoolDemo {/** * @param args */public static void main(String[] args) {// TODO Auto-generated method stubExecutorService es = Executors.newFixedThreadPool(3);for (int j = 0; j < 10; j++) {final int task = j;es.execute(new Runnable() {@Overridepublic void run() {// TODO Auto-generated method stubfor (int i = 0; i < 10; i++) {System.out.println(Thread.currentThread().getName()+ "loop of" + i + "for the task" + task);}}});}}}

还可以预定执行任务:

ScheduledExecutorService ses = Executors.newScheduledThreadPool(3);ses.schedule(new Runnable() {@Overridepublic void run() {// TODO Auto-generated method stubSystem.out.println("boming");}}, 2, TimeUnit.SECONDS);

还可以每个多长时间,执行一次任务:

ses.scheduleAtFixedRate(new Runnable() {@Overridepublic void run() {// TODO Auto-generated method stubSystem.out.println("bombing");}}, 5, 2, TimeUnit.SECONDS);

小结:

使用线程池时应该做的事情:

1、调用Execrtors类中的静态方法newCacheThreadPoolnewFixedThreadPool

2、调用submit提交RunnableCallable对象(会返还一个Future对象)

3、如果想要取消一个任务,就要保存好返回的Future对象

4、当不再提交任何任务时,调用shutdown

 

如果交给线程池运行的线程需要返回结果,给线程池添加任务时,用submit,如果不需要返回结果,就用execute方法

 


---------------------- <a href="http://www.itheima.com"target="blank">ASP.Net+Unity开发</a>、<a href="http://www.itheima.com"target="blank">.Net培训</a>、期待与您交流! ---------------------

0 0
原创粉丝点击