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

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

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

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

你可能感兴趣的:(随笔)