线程池线程数过多引起的问题

1.创建更多的线程会消耗更多的内存(这个大家都知道);
2.线程数过多,会引起频繁的线程上下文切换。那么,这个该怎么理解呢?我会结合以下代码给大家举一个例子。

synchronized (this.getClass()){
	doSomething();
}

假如,现在服务器只有一个cpu,有3个线程a,b,c,并发执行这段代码。a抢到锁时,bc还没有真正的阻塞,因为bc不知道a抢到锁了。那么,什么时候知道呢?bc获取到cpu分配的时间片后,继续向下运行,直到发现this.getClass()的对象头中已经有了锁的信息,然后bc被添加到等待队列,这时开始阻塞。在这期间,cpu将资源分配给bc线程(上下文切换),而bc两个线程除了抢锁、等待并没有做其他实质性的工作,白白浪费了cpu资源。

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值