多线程如何确定线程数

最佳线程数

在使用多线程的时候要注意几个点,1.执行这个处理的时间多长,2.执行这类任务的消息有多频繁

我一般的处理,

1.如果执行是时间过长但任务很少,我会只用一个线程(这里是无限循环,直到你的进程退出),而且最好在线程池里面直接开一个出来,不要单独去new一个线程实例,好处的话就去看下线程池跟单个线程的知识;

2.如果是执行时间短,这里就忽略掉任务的多与少,直接每次都从线程池里取一个线程来执行,因为执行时间段很快就会释放资源,这样效率很高;

3.如果执行时间长而且任务量大,那就创建线程数组,个数上我一般使用当前服务器cpu的核数的2倍,这样不会太占用资源,这种单独new出来的线程,再不使用或者关闭的时候要特别注意回收

 

try {
            threadPool = Executors.newFixedThreadPool(Constants.THREAD_SIZE);
            CountDownLatch countDownLatch = new CountDownLatch(Constants.SIZE);

            for (int i = 0; i < Constants.THREAD_SIZE; i++) {
                threadPool.execute(new Worker(countDownLatch));
            }

            countDownLatch.await();
        } catch (Exception e) {

 

posted on 2018-03-08 16:15  tigerloveapple  阅读(2810)  评论(0编辑  收藏  举报