Linux下pthread開發的一些問題

(1) 線程也是資源,注意使用pthread_join和pthread_detach回收內存

(2) mutex會將等待加鎖的線程形成一個隊列,spinlock會不斷的查詢鎖,類似於nonblock的處理

(3) pthread_cond_wait後,將會釋放掉鎖,供另外一個線程操作,操作完纔會用pthread_cond_sign喚醒, pthread_cond_wait必須要和mutex一起使用

(4) 視情況能否使用讀寫鎖

(5) 儘量使用pthread_cond_waittime取代pthread_cond_wait的死等,而且pthread_cond_wait在處理退出信號的時候存在問題

(6) 鎖中的代碼儘量的短小,防止I/O等相當耗時的操作

(7) 儘量使用環形消息隊列或者緩衝

(8) 儘量使各個線程的操作沒有相互依賴性,形成流水線操作,各個線程實現不同的任務

(9) 減少棧大小可以增加線程數

(10) pthread_join是處理處於可join的線程,必須由pthread_join調用線程來回收資源

        pthread_detach是處理處於不可join的線程,線程結束後自動回收資源

(11) 注意exit, pthread_exit, 特別是在主線程中的區別。exit是整個的進程的退出,管理線程會通知所有線程的退出。

pthread_exit只是單個線程的退出,不是進程

(12) pthread_mutex一定要先用pthread_mutex_init初始化,和destroy析構

(13) 注意LinuxThread的實現

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章