面试题-讨论一下线程数设计的问题
2020-07-19 04:49
711 查看
起源是这样的,一问朋友(super冰)让我回答下上次面试阿里的一道题目。问题是这样的:
给你一台8核16g服务器,你会给你的应用程序设计多少个线程,为什么这么设计。如果是io密集型的呢?如果是cpu密集型的呢?这里就讲讲自己的理解吧,有可能全网打脸(*▽*)。
这里就直接将io密集型和cpu密集型吧。鉴于笔者看过的源码中,比如netty之类的,默认都是给CPU核数的两倍。这里就借鉴这个经验吧。在IO密集型的机器中,个人感觉就给CPU核数的两倍吧。因为IO操作的话,应该、可能大部分操作都是文件流操作类型的,用户对系统的性能应该要求得不是那么高,因此多出来的那些线程可以处理一些其他的事情。
如果是CPU密集型的话,个人感觉就给核数+1至4个线程吧。因为CPU密集型的话,肯定是有大规模的计算过程,要是线程数量给的太多的话,就会造成CPU之间频繁的切换,那就得不偿失了。多给1-4个线程呢,我的想法是万一那个线程挂了,或者阻塞了,这些线程就该出来接力了。
当然以上都是笔者自己的想法,仅供参考。
相关文章推荐
- 关于即时通讯协议设计的问题 望和大家讨论一下
- [看到的转一下]一道.Net程序员面试题的讨论:猫大叫,鼠速逃,人醒了。
- 关于缓冲区的问题, 大家讨论一下.
- C++面试题之程序设计其他问题面试题
- [VB.NET]讨论一下海盗分金问题的vb.net解决方法
- 与大家讨论一下在视频上叠加透明窗口后闪烁的问题,求指导!
- php实现设计模式中的单例模式详解(还是不懂,那些所谓的应用场景,有没有人来讨论一下)
- 一个关于WebRequest的问题,希望大家能够讨论或指导一下小弟,谢谢
- 欢迎大家一起讨论一下pb界面中的问题
- 我也提一个关于递归的问题,代码简单,不绕,希望一起讨论一下~
- 关于用多线程时任务分配与结果收集的问题的设计讨论
- 讨论一下js获取响应中后台传回来的BigInteger类型的数字时,后几位会自动变为0的问题
- 答网友问题:职业化代码设计原则讨论 推荐
- 面试官:关于设计模式的这些问题你来回答一下
- 讨论网银应不应该承担这个网站的诚信问题?????? 希望你们能够发表一下你们的意见!!
- 答网友问题:职业化代码设计原则讨论
- Android 疑难问题讨论及面试题
- ubuntu12.04安装opencv-1.0.0的问题(希望大家进来讨论一下) (转载增补)
- winform设计一个登录界面和修改密码的界面-自动切换窗体(问题[已解] 望一起讨论)(技术改变世界-cnblog)
- winform设计一个登录界面和修改密码的界面-自动切换窗体(问题[已解] 望一起讨论)(技术改变世界-cnblog)