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

Java线程池的基础应用

2014-12-12 00:42 190 查看


了解:原子性操作类的基础用法

在java5以后,增加很多线程的内容,成为线程得并发库。

在java.util.concurrent包及子包的API帮助文档,上面有对并发库涉及内容

在java.util.concurrent.atomic包,有对基本数据,对数组中的基本数据,类中的基本数据等的操作

AtomicIneger类,可以解决多线程访问整数的问题

AtomicBoolean.....

AtomicArray...操作数组的基本数据

AtomicIntegerFieldUodater<T>,操作类中的基本数据

并发库的基本应用:

关于线程池的理解加深

以前只是知道有线程池这个东西,并不是很了解。

第一种方式:


Executors工具类,创建一个线程池,固定的线程池

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

public class ThreadAtomic {

public static void main(String[] args) {

//5个线程的线程池
ExecutorService threadPool = Executors.newFixedThreadPool(5);
for(int j = 1;j<=10;j++){
final int task = j;
threadPool.execute(new Runnable(){

public void run() {
for(int i = 1;i<=10;i++){
try {
Thread.sleep(30);
} catch (Exception e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()+
" is running "+i+" for task is "+ task);
}
}
});//向池子中添加任务
}
System.out.println("10 task is over");
}
}

会发现,每次都只有5个任务在执行,执行到10次,后再换下5个任务

所以,池子中有n个线程,向池子中添加m个任务,能被执行的任务的最大数是n个,剩下的还未被执行的任务还在排队等待。而且,不结束,因为池子中还有线程,虽然没事干,但还是在等待threadPool.shutdownNow()/shutdown(),结束,就算还有任务也会被结束,该方法就是杀死池子中的所有线程。


第二种:

缓存的线程池,简单说就是线程池中的线程个数不确定,当有3个任务的时候,池子中的线程就是3个,每个线程拿一个任务做,当任务减少

时,池子中的多余线程会被回收,总之,池子中的线程是动态的

ExecutorService threadPool = Executors.newCachedThreadPool();

第三种:

只有一个线程的线程池,实际上不能叫做线程池,但是该线程池有一个好处,就是池中的线程死掉了,会自动创建一个新的线程,总之,

会保证池子中有一个线程存在,这也就可以解决,如何在线程死掉以后使其重新启动
ExecutorService threadPool = Executors.newSingleThreadExecutor();

用线程池启动定时器

调用ScheduledExectorService的schedule方法,返回的scheduleFuture对象可以取消任务

支持间隔重复任务的定时方式,不直接支持绝对定时方式,需要转换成相对时间方式

Executors.newScheduledThreadPool(3).schedule(new Runnable() {

public void run() {
System.out.println("ok!");
}
}, 3, TimeUnit.SECONDS);
//3秒后打印ok

Executors.newScheduledThreadPool(3).scheduleAtFixedRate(new Runnable() {

public void run() {
System.out.println("ok!");
}
}, 3,2, TimeUnit.SECONDS);

//3秒后ok,以后每隔2秒ok

注意它没有提供,比如今天晚上9点...的方法,所以可以用今天晚上9点的毫秒值-当前时间的毫秒值,来设置
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: