这几天跑多线程;
一个线程的时候可能10分钟左右就跑完了,本来想多开几个线程,跑的快一点,没想到,开了10个线程之后.....
理论来说,10个线程应该1分钟就跑完了,但是不是,10个线程跑完还是用了10分钟左右......
不知道这是什么情况,我这理论知识很差,实在百思不得其解,希望哪位大大来解答一下;
不知道自己表达的对不对,反正意思就是,多线程并没有加快速度,缩短程序跑得时间;
这几天跑多线程;
一个线程的时候可能10分钟左右就跑完了,本来想多开几个线程,跑的快一点,没想到,开了10个线程之后.....
理论来说,10个线程应该1分钟就跑完了,但是不是,10个线程跑完还是用了10分钟左右......
不知道这是什么情况,我这理论知识很差,实在百思不得其解,希望哪位大大来解答一下;
你这个并发量这么小,就算十个线程,仍然是使用CPU的一个内核,那么就说明十个线程都是使用这一个CPU,那么就存在资源的抢占,但注意不管怎么抢占,都只有一个内核在干活,如果你起100个线程,每个线程循环10000000次,那么你就会发现,一个线程循环1000000000的速度肯定没有100个线程分别循环10000000次快。
总结:这么点线程和任务没有参考意义,建议加大线程和任务内容。
工具:用Visual VM这个工具实时的看当前线程是否完全并发执行,如果不是并发执行,那么则说明只用了一个CPU内核,如果同时存在多个线程完全并发执行,说明就是用了多个CPU内核了