---------------------- <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()实现对count加1操作,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 stub
ExecutorService es = Executors.newFixedThreadPool(3);
for (int j = 0; j < 10; j++) {
final int task = j;
es.execute(new Runnable() {
@Override
public void run() {
// TODO Auto-generated method stub
for (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() {
@Override
public void run() {
// TODO Auto-generated method stub
System.out.println("boming");
}
}, 2, TimeUnit.SECONDS);
还可以每个多长时间,执行一次任务:
ses.scheduleAtFixedRate(new Runnable() {
@Override
public void run() {
// TODO Auto-generated method stub
System.out.println("bombing");
}
}, 5, 2, TimeUnit.SECONDS);
小结:
使用线程池时应该做的事情:
1、调用Execrtors类中的静态方法newCacheThreadPool或newFixedThreadPool
2、调用submit提交Runnable或Callable对象(会返还一个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>、期待与您交流! ---------------------