package SJMS;
public class Test1 {
public static void main(String[] args) {
for (int i = 0; i < 10000000; i++) {
new Thread(new Runnable() {
public void run() {
try {
Thread.sleep(9000 * 9000 * 9);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}).start();
System.out.println(i);
}
}
}
new出几十万个线程,并让其休眠很长时间,占用内存。一会cpu利用率满了,内存也满了,说明线程不是越多越好,还得看内存能不能带动。
并且线程创建和销毁都要消耗很多时间的,如果创建消耗的时候大于执行任务的时候,就没有必要多线程了。
因为才有了线程池,这样就避免了频繁创建消耗线程了。
同时cpu频繁在各个线程之间切换影响性能。
线程的本质,就是把代码送给cpu取执行
我们需要做的就是选择合适数量的卡车,不断运输代码即可。