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();
}
}
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();
}
}
相关文章推荐
- 运用JAVA的concurrent.ExecutorService线程池实现socket的TCP和UDP连接
- java-ExecutorService实现线程池
- 运用JAVA的concurrent.ExecutorService线程池实现socket的TCP和UDP连接
- 运用JAVA的concurrent.ExecutorService线程池实现socket的TCP和UDP连接
- java线程池工具类代码(利用java官方线程池类ExecutorService实现)
- 运用JAVA的concurrent.ExecutorService线程池实现socket的TCP和UDP连接
- java的ExecutorService 实现线程池
- java利用线程池(ExecutorService)配合Callable和Future实现执行方法超时的阻断
- 【Java线程】Java线程池ExecutorService
- Java线程池介绍(ExecutorService)
- Java Thread&Concurrency(12): 深入理解AbstractExecutorService及其实现原理
- Android(Java) 线程池ExecutorService 使用的注意事项
- java android ExecutorService 线程池解析
- java ExecutorService 线程池Callable 和 Future接口
- 使用Spring中的线程池ThreadPoolTaskExecutor实现JAVA并发
- 《java.util.concurrent 包源码阅读》10 线程池系列之AbstractExecutorService
- java android ExecutorService 线程池解析
- Java线程池(Android拥有与Java相同的ExecutorService实现)
- java ExecutorService 线程池
- ExecutorService来进行线程池的方式实现多线程