面试题-讨论一下线程数设计的问题

3 篇文章 0 订阅

    起源是这样的,一问朋友(super冰)让我回答下上次面试阿里的一道题目。问题是这样的:给你一台8核16g服务器,你会给你的应用程序设计多少个线程,为什么这么设计。如果是io密集型的呢?如果是cpu密集型的呢?这里就讲讲自己的理解吧,有可能全网打脸(**)。

    这里就直接将io密集型和cpu密集型吧。鉴于笔者看过的源码中,比如netty之类的,默认都是给CPU核数的两倍。这里就借鉴这个经验吧。在IO密集型的机器中,个人感觉就给CPU核数的两倍吧。因为IO操作的话,应该、可能大部分操作都是文件流操作类型的,用户对系统的性能应该要求得不是那么高,因此多出来的那些线程可以处理一些其他的事情。

    如果是CPU密集型的话,个人感觉就给核数+1至4个线程吧。因为CPU密集型的话,肯定是有大规模的计算过程,要是线程数量给的太多的话,就会造成CPU之间频繁的切换,那就得不偿失了。多给1-4个线程呢,我的想法是万一那个线程挂了,或者阻塞了,这些线程就该出来接力了。

    当然以上都是笔者自己的想法,仅供参考。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值