线程数以及虚拟内存大小的关系
来源:互联网 发布:滨州行知中学 后悔 编辑:程序博客网 时间:2024/06/02 22:31
之前有个小项目,具体需求是:
完成一个客户端,按照某一速度向服务器发送Radius请求,并处理服务器返回的响应.
实现方案:
采用多线程方式实现,每个线程负责发送请求,并等待服务器返回的响应.
测试发现,发送速度达到某个值时就无法增加了,日志显示内存不够,无法创建更多线程. 进而发现可以创建不到400个线程.
实际上,这里的内存不足是指虚拟内存不足(这个项目里每个线程需要的物理内存很小),对于32位系统,虚拟内存空间大约4G, 其中低3G内存空间分配给用户空间(windows通常分配2G空间给用户空间)
此外,进程每创建一个线程,会分配固定大小的虚拟空间作为线程的栈空间(通常是8M,这个值可调), 因此当进程创建了大约不到400个线程系统就出现内存空间不够的提示,无法再创建更多线程了.
必须说明的是, 这里采用的实现方案是有问题的:
1)每个线程不必等待服务器返回的响应,由一个线程专门负责接收报文即可,然后由这个线程分发给其他线程处理.
2)也不必创建几百个线程,有几个就行了,具体多少可以写个专题了.
- 线程数以及虚拟内存大小的关系
- 线程池大小设置,CPU的核心数、线程数的关系和区别,同步与堵塞完全是两码事
- 进程与线程栈大小的调整(vsz 虚拟内存大小)
- 进程与线程栈大小的调整(vsz 虚拟内存大小)
- 进程与线程栈大小的调整(vsz 虚拟内存大小)
- ubuntu下cpu数,核心数,线程数的关系
- ubuntu下cpu数,核心数,线程数的关系
- Linux下cpu数,核心数,线程数的关系
- 进程和线程的关系以及区别
- CPU的核心数、线程数的关系和区别
- CPU的核心数、线程数的关系和区别
- 设置tomcat的jvm的虚拟内存大小
- 修改Tomcat 的虚拟内存的大小
- 测试进程占用的虚拟内存大小
- 5.虚拟内存的概念、特征以及虚拟内存的实现
- 谈虚拟内存与物理内存的关系
- CPU、内存、虚拟内存、硬盘之间的关系
- CPU、内存、虚拟内存、硬盘之间的关系
- Oracle递归 Start with 和Connect By
- 获取DC的几种方法
- 对一个8位的二进制数进行位倒序
- Linux ALSA声卡驱动之一:ALSA架构简介
- 网站防止CC攻击的方法
- 线程数以及虚拟内存大小的关系
- 如何让Android系统或Android应用执行shell脚本
- 中国电视剧不接地气
- [Android] ImageButton | Button | TextView 点击和触摸效果实现
- 初学者怎么去提问?要注意提问的方法
- 手把手教你BCGControlBar MFC界面控件“起航”技巧(文章转载自:慧都控件网)
- spring配置文件中Bean中的id和name的区别
- QT 调用外部程序
- 电子墨水技术进入中国智能手机