这几天跑多线程;
一个线程的时候可能10分钟左右就跑完了,本来想多开几个线程,跑的快一点,没想到,开了10个线程之后.....
理论来说,10个线程应该1分钟就跑完了,但是不是,10个线程跑完还是用了10分钟左右......
不知道这是什么情况,我这理论知识很差,实在百思不得其解,希望哪位大大来解答一下;
你这个并发量这么小,就算十个线程,仍然是使用CPU的一个内核,那么就说明十个线程都是使用这一个CPU,那么就存在资源的抢占,但注意不管怎么抢占,都只有一个内核在干活,如果你起100个线程,每个线程循环10000000次,那么你就会发现,一个线程循环1000000000的速度肯定没有100个线程分别循环10000000次快。
总结:这么点线程和任务没有参考意义,建议加大线程和任务内容。
工具:用Visual VM这个工具实时的看当前线程是否完全并发执行,如果不是并发执行,那么则说明只用了一个CPU内核,如果同时存在多个线程完全并发执行,说明就是用了多个CPU内核了
多线程的意义不是你这么理解的,多线程不是缩短总程序的运行时间,而是将事件拆分,异步分配任务。举个简单的例子。比如你要吃火锅,你叫A去买底料,B去买肉,C去买菜,你在家烧水。那很快就能吃到火锅了。但是这些所有的事项,你非要把你们都困在一起按同样的操作去一个个完成,那总时间是不是一样的?
不管开1个线程还是开10个线程,线程的任务都是相同的,因此时间消耗基本相同。
如果想要提高效率,正确方式是把1个主任务拆成10个子任务,每个线程执行一个子任务,而不是10个线程执行10个主任务。
第一:
你这是搞了10个线程同时干自己的事情吧?
size等于1 启动一个线程处理list.get(0)的事件,类似只完成了10%
size等于10 启动十个线程处理10个list里面的事件,类似完成了100%
第二:
看你的cpu
并发大于cpu个数的时候,会一直上下文切换,一个cpu只能同时执行一个线程
你这个比较 是一个线程干一件事10分钟;然后10个线程干10件事,那不还得10分钟
你这个代码实际是十个线程同时跑十个任务,这个任务本身就耗时十分钟,而并不是十个线程共同处理一个任务。