线程池最大线程数判断

很多时候用到线程池技术,那线程池中最大线程数是多少,或者多少线程是系统运行最稳定的。

int maxthread = Runtime.getRuntime().availableProcessors() * 25;//最大线程数=cpu个数*25,超过这个值系统运行会不稳定(仅限于服务器,自己的电脑不能达到这个数)。

Runtime.getRuntime().totalMemory();// Java 虚拟机中的内存总量

Runtime.getRuntime().freeMemory()//Java 虚拟机预留内存

Runtime.getRuntime().maxMemory()//Java 虚拟机试图使用的最大内存量

计算线程可有使用的内存  理论上:最大内存量- 虚拟机预留内存,实际上:虚拟机中的内存总量-虚拟机预留内存

线程池判断所有线程是否执行完毕通常有两种方法: 1. **Future集合**:如果你使用的是`ExecutorService`并提交了`Runnable`或`Callable`任务,可以使用`Future`接口的`get()`方法。这个方法会阻塞,直到对应的线程执行完成并且结果可用。你可以将所有Future放入List中,然后遍历这个列表,当所有的`get()`都返回或抛出异常时,表示所有任务已完成。 ```java List<Future<?>> futures = executor.invokeAll(tasks); for (Future<?> future : futures) { try { future.get(); // 如果抛出InterruptedException或ExecutionException,则线程未完成 } catch (InterruptedException | ExecutionException e) { // 处理异常,如日志记录或取消剩余任务 } } ``` 2. **CountDownLatch**:如果任务的量是已知的,可以创建一个`CountDownLatch`计器,每个任务完成后调用其`countDown()`方法,主线程持有`CountDownLatch`实例并在所有任务完成后释放它。 ```java CountDownLatch latch = new CountDownLatch(poolSize); for (Runnable task : tasks) { pool.execute(() -> { try { task.run(); } finally { latch.countDown(); // 线程结束时减少计器 } }); } latch.await(); // 主线程阻塞等待所有任务完成 ``` 3. **Semaphore**:如果你需要更复杂的同步策略,比如允许某个资源在一定时间内被访问多次,可以使用`Semaphore`。当所有任务完成时,信号量的许可证量会恢复到最大值。 无论哪种方法,都需要确保正确的异常处理和线程安全,以及考虑到异常情况下的清理工作。在实际应用中,结合业务需求和线程池的具体实现选择合适的方法。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值