xiaogang
2021-05-21 05f5fcc1efbd628f08c868fdaf622554ff85271a
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
/*
 * Copyright 2017-2020 吴学文 and java110 team.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.java110.core.factory;
 
import java.util.LinkedList;
import java.util.List;
import java.util.Vector;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
 
/**
 * @ClassName Java110ThreadPoolFactory
 * @Description java110提供线程池工厂类
 * @Author wuxw
 * @Date 2021/1/14 21:04
 * @Version 1.0
 * add by wuxw 2021/1/14
 **/
public class Java110ThreadPoolFactory<T> {
 
    public static final int JAVA110_DEFAULT_THREAD_NUM = 5;
    private Vector<Future<T>> futureList = null;
    ExecutorService executor = null;
 
    public static Java110ThreadPoolFactory getInstance() {
        return new Java110ThreadPoolFactory();
    }
 
    /**
     * 创建 线程池
     *
     * @param defaultThreadNum 线程数量
     * @return
     */
    public Java110ThreadPoolFactory<T> createThreadPool(int defaultThreadNum) {
        futureList = new Vector<>();
        executor = Executors.newFixedThreadPool(defaultThreadNum);
        return this;
    }
 
 
    public Java110ThreadPoolFactory submit(Callable<T> task) {
        Future<T> result = executor.submit(task);
        futureList.add(result);
        return this;
    }
 
    public List<T> get() {
        List<T> result = new LinkedList<>();
        for (Future<T> future :
                futureList) {
            try {
                result.add(future.get());
            } catch (Exception e) {
                result.add(null);
            }
 
        }
        return result;
    }
 
    public void stop() {
        executor.shutdown();
    }
}