线程池基本理论
主要特點:
?????? 完成同一種任務的一組線程。(一般初始線程數>=64)
?
?
?原理:
?????? 通過“事先創建一堆線程,并且執行完后不銷毀”的方式,避免每次任務到來時,
???? 都要創建線程的開銷。
?
?主要組成部分:
?????? 線程池管理器(ThreadPoolManager): 創建線程池
??????????????????????????????????? ? ? ? ? ? ? ? ? ? ? ?? 添加新任務
?????????????????????????????????????????????????????????? 銷毀線程池
?????? 工作線程(WorkThread): 線程池中的所有線程
?????? 任務接口(Task):每個任務必須實現的接口,以供工作線程調度任務的執行。
?????? 任務隊列(TaskQueue):用于存放沒有處理的任務。提供一種緩沖機制。
?基本操作:
?????? 一般情況下是首先初始化一定數量的工作線程,并把任務提交給空閑的線程,當線
??? 程都處于忙的狀態的時候,則重新生成新的工作線程,當空閑線程較多的時候則停止一
??? 部分線程,這些要看你自己的調度算法。但是線程不能濫用,因為并不是線程越多就會
??? 帶來更好的性能,這些都要看你的具體應用,具體可以參照侯捷先生的《windows多線
??? 程程序設計》
?
?何時使用:
??? 當系統需要頻繁啟動線程,且完成任務的時間較短時,使用線程池能有效的提高性能。
??? PS:之所以要強調任務的執行時間較短,是因為:如果任務執行時間很長(eg:數據庫訪
?????? 問),那么“節省線程對象創建時間”對提升整體性能的作用是很有限的。
?優化線程池設計:
??? a)動態改變工作線程數量
????? 設置好線程池的上限和下限。為應對突發訪問量增加的情況,防止大量任務積壓在任
??? 務隊列中,動態“批量增加工作線程”;訪問量下降后可適當減少工作線程數。
????? eg:SqlServer單進程多線程模式,1024個數量的線程池,動態線程分配,理論上限32767。
?? ?
??? b)優化成合適的工作線程數量
?????? 調試時,根據“統計規律”選擇“預期訪問頻率”下,效率最高的初始工作線程數量。
??? c)多個線程池
?????? 根據不同任務或者任務優先級來采用不同線程池處理,一般用于復雜系統中。
轉載于:https://www.cnblogs.com/edisonfeng/archive/2012/06/27/2565966.html
總結
- 上一篇: tomcat5 remote debug
- 下一篇: unicode 版本 delphi (如