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

java ListeningExecutorService线程池的实现

2017-12-05 12:08 477 查看
package duoXianChengs;

import java.util.ArrayList;

import java.util.List;

import java.util.concurrent.CountDownLatch;

import com.google.common.util.concurrent.ListeningExecutorService;

public class duoxiancheng3 {
static CountDownLatch cdl;// 线程的数目
static List<String> colList = new ArrayList<String>();
public static void main(String[] args) {
ThreadPools kk = new ThreadPools();
ListeningExecutorService pool = kk.getPool();
cdl = new CountDownLatch(5);// 开启线程的数目
for (int i = 0; i < 5; i++) {
submitTest(pool, colList);
}
try {
cdl.await();// 主线程等待子线程执行完成
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
for (String gg : colList) {
System.out.println(gg);
}
System.out.println(colList.size());
colList.clear();
}

/**

*
* @param pool
* @param insertList
*/
static void submitTest(ListeningExecutorService pool,List<String> insertList) {
pool.submit(() -> {
insertList.add("333");
try {
inc();
} catch (Exception e) {
e.printStackTrace();
}
});
}
/* 上面那种写法就如下面注释掉的写法一样 jdk1.8的功能
static void submitTest1(ListeningExecutorService pool,List<String> insertList) {
pool.submit(new Runnable() {

@Override
public void run() {
insertList.add("333");
try {
inc();
} catch (Exception e) {
e.printStackTrace();
}

}
});
}*/

static synchronized void inc() throws InterruptedException {// 注意,如果不加上synchronized,由于并发写入,结果会不准确
Thread.sleep(1);
cdl.countDown();
}
}

package duoXianChengs;

import com.google.common.util.concurrent.ListeningExecutorService;

import com.google.common.util.concurrent.MoreExecutors;

import javax.annotation.PreDestroy;

import java.util.concurrent.Executors;

public class ThreadPools {

    final ListeningExecutorService pool = MoreExecutors.listeningDecorator(Executors.newFixedThreadPool(10));//设置线程池个数

    public ListeningExecutorService getPool() {

        return pool;

    }

    @PreDestroy

    public void close() {

        pool.shutdown();

    }

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息