我们可以设置java.util.concurrent.ForkJoinPool.common.parallelism java属性吗?
System.out.println("getParallelism=" +ForkJoinPool.commonPool().getParallelism());
System.setProperty("java.util.concurrent.ForkJoinPool.common.parallelism","20");
Thread.sleep(1000);
System.out.println("getParallelism=" +ForkJoinPool.commonPool().getParallelism());打印:
getParallelism=3
getParallelism=3 发布于 2018-02-27 21:28:42
您必须在应用程序启动之前设置参数。因此,传递一个JVM参数
-Djava.util.concurrent.ForkJoinPool.common.parallelism=20
在启动时将其更改为20。
发布于 2019-04-30 07:51:44
否则,您可以创建自定义池并实现所需的并行度
int numTasks = 20;
ForkJoinPool pool = new ForkJoinPool(numTasks);
System.out.println("getCustomParallelism=" +pool.getParallelism()); //prints 20发布于 2020-12-14 14:27:51
动态设置在它是第一个访问池的语句时起作用。尝试删除获取并打印默认并行度的第一行。只使用下面的内容。
System.setProperty("java.util.concurrent.ForkJoinPool.common.parallelism","20");
System.out.println("getParallelism=" +ForkJoinPool.commonPool().getParallelism());https://stackoverflow.com/questions/49009662
复制相似问题