pthread 的坑
為什么寫這篇文章?
嵌入式Linux:pthread_create 記錄線程使用?zhuanlan.zhihu.com
這是上篇文章使用了pthread_create來實現閃爍led燈,因為代碼寫的有偏差導致了一個問題,就是不能進入深度休眠
問題產生原因
先了解下互斥鎖
線程之間可以共享內存空間,這意味著不同線程可以訪問內存中的同一個變量。然而不同線程在同一時間修改一個內存對象會造成一些不可預知的結果。
為了避免意外,我們需要用到pthread里一個非常重要的數據結構 —— 互斥對象(mutex)。互斥對象在使用時結合互斥鎖使用,pthread_mutex_lock 和 pthread_mutex_unlock。
互斥鎖是這樣工作的:線程B鎖定了一個互斥對象(mymutex),如果線程A也試圖鎖定該互斥對象(mymutex)時,線程A就進入休眠狀態。一旦線程B釋放了互斥對象(調用 pthread_mutex_unlock()) ,線程A 就能夠鎖定這個互斥對象(換句話說,線程A就將從 pthread_mutex_lock() 函數調用中返回,同時互斥對象被重新鎖定)。同樣地,當線程A正鎖定互斥對象時,如果線程C試圖鎖定互斥對象的話,線程C也將臨時進入睡眠狀態。
pthread_mutex_lock(&mymutex);/*直至解鎖后,mymutex會阻止另一個試圖訪問此區域的線程*/ pthread_mutex_unlock(&mymutex);對已鎖定的互斥對象上調用 pthread_mutex_lock() 的所有線程都將進入睡眠狀態,這些睡眠的線程將“排隊”訪問這個互斥對象。
從上述可知,mute
總結
以上是生活随笔為你收集整理的pthread 的坑的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Activiti6.0 - 核心数据库表
- 下一篇: Secure CRT 自动记录日志