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