以问答形式展开,会更有针对性:
1、工作线程是不是越多越好?

不是。a、服务器cpu核数有限,所以同时并发或者并行的线程数是有限的,所以1核cpu设置1000个线程是没有意义的。

b、线程切换也是有开销的。频繁切换线程会使性能降低。

2、调用sleep()函数的时候,县城是否会占用着CPU?

不占用,sleep()函数切换时会把cpu让出来。accept()阻塞和recv()阻塞时也会让出cpu。

3、cpu单核,做多线程有用吗?

多线程并发是有用的,但是起的线程数量太多会造成线程频繁上下文切换,开销大,性能衰弱。

好了,回到我们主题,我们希望确定线程池中核心线程数的大小。之前来看的《java并发编程实战》,里面有讲,要正确地设置线程池的大小,你必须估算出任务的等待时间和计算时间的比值,这种估算不会很精确。也可以使用另一种方式,就是:在某一个基准负载下,分别设置不同大小的线程池来运行应用程序,并观察cpu利用率的水平。

先将按公式计算线程池的大小,公式如下:

    对于,线程池中线程的个数,在《java虚拟机并发编程》中会定义如下:

线程数=cpu可用核心数/(1-阻塞系数),其中阻塞系数的取值在[0,1]之间。计算密集型任务的阻塞系数为0,而IO密集型任务的阻塞系数则接近1。一般,我们让线程执行的任务是比较复杂的,不会是单一的计算密集型任务,或者单一的IO密集型任务,通常会夹杂着。那么就需要我们去计算阻塞系数了。阻塞系数的定义就是执行该任务阻塞的时间与(阻塞时间+计算时间)的比值,也就是w/(w+c)。

两本书中对于可用线程数的定义公式是不一样的,但是到底原理是不是一样的呢?我们用假设法验证一下:假设两个公式计算的线程数是一样的,也就是说,得到如下等式:

也就是说,两本书上的公式原理是一样的,那么我们就可以方便使用了,这边可以考虑使用<java并发编程实战>的公式,因为他考虑到cpu使用率。也就是说我们在实际使用时,可以根据以上的公式计算出,服务器上能够长期存在的线程个数。可以设置CPU的使用率,cpu的可用核数可以通过java中的以下方法获得:

Runtime.getRuntime().availableProcessors()

该方法的注释可以理解用处:

/*** Returns the number of processors available to the Java virtual machine.** <p> This value may change during a particular invocation of the virtual* machine.  Applications that are sensitive to the number of available* processors should therefore occasionally poll this property and adjust* their resource usage appropriately. </p>** @return  the maximum number of processors available to the virtual*          machine; never smaller than one* @since 1.4*/
public native int availableProcessors();
/*
返回Java虚拟机可用的处理器数。** <p>在特定的虚拟机调用期间,此值可能会更改。 因此,对可用处理器数量敏感的应用程序应偶尔轮询此属性并适当调整其资源使用情况。</ p>** @return虚拟机可用的最大处理器数量; 永远不会小于一个所以在性能敏感的应用中,创建线程池时,最好根据这个值来动态设定线程池的核心线程数。
*/

那么w/c怎么计算呢?可以将你的需要执行的任务量化,你需要确定哪些步骤是IO操作,哪些步骤的计算操作,然后跑一次,来确定执行这个任务耗费在IO多少时间,耗费在计算上多少时间,两者的比值就是W/C。在知道cpu可用核心数,预期的cpu使用率,和W/C这些值之后就可计算出工作线程数的大小了。

这边介绍一下一般经验:

IO密集型:如果存在ID,那么w/c>1,阻塞耗时一般都会比计算耗时的很多倍。如果不想做以上的计算,那么可以设置工作线程数为2倍cpu可用线程数。IO包括:数据库交互,文件上传下载,网络传输等

计算密集型:工作线程数就是cpu可用核数。这样比较保险

Java 确定线程池中工作线程数的大小相关推荐

  1. Java 线程池中的线程复用是如何实现的?

    前几天,技术群里有个群友问了一个关于线程池的问题,内容如图所示: 关于线程池相关知识可以先看下这篇:为什么阿里巴巴Java开发手册中强制要求线程池不允许使用Executors创建? 那么就来和大家探讨 ...

  2. java线程池newfi_Java 线程池中的线程复用是如何实现的?

    前几天,技术群里有个群友问了一个关于线程池的问题,内容如图所示: 那么就来和大家探讨下这个问题,在线程池中,线程会从 workQueue 中读取任务来执行,最小的执行单位就是 Worker,Worke ...

  3. linux下c语言线程传参数,【linux】C语言多线程中运行线程池,在线程池中运行线程池,,传递的结构体参数值为空/NULL/0...

    C语言多线程中运行线程池,在线程池中运行线程池,,传递的结构体参数值为空/NULL/0 本贴问题,之前已经提问过一次,当时已经解决了,原贴在这里https://segmentfault.com/q/1 ...

  4. python 判断线程是否执行完毕_判断线程池中的线程是否全部执行完毕

    在使用多线程的时候有时候我们会使用 java.util.concurrent.Executors的线程池,当多个线程异步执行的时候,我们往往不好判断是否线程池中所有的子线程都已经执行完毕,但有时候这种 ...

  5. 判断线程池中的线程是否全部执行完毕

    在使用多线程的时候有时候我们会使用 java.util.concurrent.Executors的线程池,当多个线程异步执行的时候,我们往往不好判断是否线程池中所有的子线程都已经执行完毕,但有时候这种 ...

  6. 一个线程池中的线程异常了,那么线程池会怎么处理这个线程?

    一个线程池中的线程异常了,那么线程池会怎么处理这个线程? 参考文章: (1)一个线程池中的线程异常了,那么线程池会怎么处理这个线程? (2)https://www.cnblogs.com/fangua ...

  7. 判断线程池中某个线程是否执行完成

    目录 1.先写结果 2.判断某个线程是否执行完成(不使用线程池) 3.在线程池中不能使用isAlive判断线程状态的原因 3-1.错误示例 3-2.创建线程工厂 3-3.创建线程方法(ThreadPo ...

  8. c语言数据库线程池,C语言多线程中运行线程池,在线程池中运行线程池,,传递的结构体参数值为空/NULL/0...

    typedef struct { }LoanInfos; typedef struct{ int cp;//主线程编号 int thread;//线程编号 long int time; int arr ...

  9. 线程池中的线程复用原理

最新文章

  1. 山社电机: SAMSR -外部接口测试
  2. Matlab Robotic Toolbox V9.10工具箱(四):常用函数
  3. 生成和合入patch的两种方式
  4. SVN 集中式版本管理工具
  5. 常见异常代码oracle
  6. python中0、1、True、False、if条件
  7. 如何在Github上找到“最受欢迎的存储库”? [关闭]
  8. 关于Redis热点key的一些思考
  9. 2014 - 2015
  10. 程序员如何切入区块链去中心化应用开发 1
  11. re模块和正则表达式
  12. nagios介绍及Server安装(三)
  13. app开发需要哪些技术?4种app制作方法对比
  14. 计算机会计什么是对应结转,会计科目对应关系
  15. saltstack实战--远程执行之返回(returner)
  16. pc端MNIST数据集pytorch模型CNN网络转换为onnx部署树莓派4B和神经棒NCS2(使用openvino2021框架)
  17. 矩阵在游戏开发中的应用
  18. 如何远程登陆Linux服务器
  19. Python动物图像分割API简单调用实例演示,阿里达摩院视觉智能开放平台使用步骤
  20. 文本标注工具--BRAT 安装

热门文章

  1. PC比电脑好玩的秘密是什么?答案就是因为有这些神奇的网站!
  2. 使用 Python 生成二维码
  3. 计算机学校属于什么学历,技校毕业是什么学历 技校属于什么文凭
  4. 输入你的密码来连接到_手机无线网络可以连接但上不了网如何解决【详解】
  5. C# 在wpf中如何使用image
  6. WIN 7和WIN 10添加和删除静态路由
  7. 使用elasticsearch1.5.2查询指定距离范围内的城市(类似微信附近的人)
  8. MinGW介绍与使用
  9. truffle unbox react 初始化踩坑
  10. java问卷导入excel_Java利用已有的Excel文件导出新的Excel