從任務角度上思考:在單核CPU上運行多線程程序有意義嗎?
問題假設: _ _ _ _ _ 為單位時間內CPU的工作狀態。T為Thread,?_ _ _ T _? 表示單位時間內java程序只使用了 1/5的運算能力
具體任務:查詢公司所有員工1~3年的考勤記錄
單CPU單線程執行任務:
????一次性查詢1~3年的的員工考勤記錄
????CPU利用率: T? _ _ _?_ _T _ _?_ _?_ T _ _?_ _?_ 完成 , 使用了三個周期, 其他空閑的時間交給了操作系統的其他任務
單CPU多線程執行任務:導出1~3年的考勤記錄
????使用三個線程分別查詢第1年、第2年、第3年的員工考勤記錄 T = T1 + T2 +T3
????單CPU多線程的CPU利用率: T1 _ T2 _ T3, 只使用了一個周期的時間完成任務。
我可不可以認為: 單CPU多線程,是盡力在壓榨CPU的使用率。?
另外,當CPU已經被擠滿。單CPU多線程的性價比應該辯證來看,如果有IO操作,依舊是高性價比的操作,
如果是查詢公司所有員工1~3年的考勤記錄,多線程的操作既增加了上下文切換也并沒有成功壓榨到CPU時間,所以性價比低。
以上是我的思考,想問悟空老師,我的想法是否有誤區?
2019-11-09
?單CPU多線程,是盡力在壓榨CPU的使用率,是對的,如果有IO操作,很多線程會休息,如果單線程,那么CPU就休息。如果CPU已經被擠滿,那么并不是說
在單核CPU上運行多線程程序沒有意義,而是說,線程的數量設置不合理,應該減少線程的數量。