看過一本書,上面說到為什么使用多線程可以提高效率,主要的原因有兩個(gè):IO等待和多CPU。多CPU顯然有多個(gè)CPU就可以同時(shí)執(zhí)行多個(gè)任務(wù),每個(gè)線程就相當(dāng)于一個(gè)任務(wù)。IO等待假如有一個(gè)線程在執(zhí)行的時(shí)候,遇到了磁盤讀寫或者網(wǎng)絡(luò)傳輸阻塞,那么線程就需要等待,這時(shí)候占用的CPU就可以釋放,然后CPU就可以將時(shí)間片分給其他線程,等待這個(gè)線程IO等待結(jié)束了,CPU再把時(shí)間片分給它,這樣就可以合理安排CPU時(shí)。如果是計(jì)算型的線程,那么計(jì)算型線程的個(gè)數(shù)不要超過CPU的個(gè)數(shù),因?yàn)橛?jì)算型線程沒有IO等待,會(huì)一直運(yùn)行,那么就會(huì)一直占用CPU資源,所以CPU就不會(huì)切換去執(zhí)行其他的線程,這種情況下如果計(jì)算型線程數(shù)多于CPU個(gè)數(shù)的話,就沒有CPU能夠空出來去執(zhí)行多出來的線程。我的疑問是不是并不是一定要有IO阻塞才能利用多線程,比如可以在一個(gè)線程的執(zhí)行方法里面使用sleep,讓線程睡眠,也產(chǎn)生了線程等待的效果,這時(shí)候CPU就會(huì)去執(zhí)行其他線程,是不是這樣?另外,四種線程同步的方式(臨界區(qū)、互斥對(duì)象、事件對(duì)象、信號(hào)量),比如線程在等待事件對(duì)象的時(shí)候,CPU是會(huì)一直執(zhí)行這個(gè)線程還是在這個(gè)等待的時(shí)間去執(zhí)行其他的線程?其他的幾種線程同步方式,CPU是怎么分配時(shí)間片的?
多線程在什么時(shí)候使用合適
幕布斯6054654
2019-04-14 10:40:29