您好,登錄后才能下訂單哦!
本篇內容介紹了“QT互斥量怎么實現”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
訪問同一數據的多個任務(線程)的代碼隨機交替執行,是任務(線程)間數據交換不能正常進行的原因。那么對策就顯而易見:想辦法讓訪問同一段數據的代碼不會同時(時間上有交叉)執行即可。
其實也說不上想辦法,因為操作系統已經將這種機制準備好了:mutex(互斥量)
互斥量實例(QT環境)
執行結果
今天換個順序,先看執行結果。
WT:<<<<WriteData:7<<<<
WT:int DataArray::addData(0)
WT:{
WT: if(m_dataSize < (ARRAY_SIZE - 1))
WT: {
WT: m_buffer[0] = 0;
WT: m_dataSize++;
WT: }
WT:}
WT:int DataArray::addData(1)
WT:{
WT: if(m_dataSize < (ARRAY_SIZE - 1))
WT: {
WT: m_buffer[1] = 1;
WT: m_dataSize++;
WT: }
WT:}
WT:int DataArray::addData(2)
WT:{
WT: if(m_dataSize < (ARRAY_SIZE - 1))
WT: {
WT: m_buffer[2] = 2;
WT: m_dataSize++;
WT: }
WT:}
WT:int DataArray::addData(3)
WT:{
WT: if(m_dataSize < (ARRAY_SIZE - 1))
WT: {
WT: m_buffer[3] = 3;
WT: m_dataSize++;
WT: }
WT:}
WT:int DataArray::addData(4)
WT:{
WT: if(m_dataSize < (ARRAY_SIZE - 1))
WT: {
WT: m_buffer[4] = 4;
WT: m_dataSize++;
WT: }
WT:}
RT:>>>>ReadData:8>>>>
RT:int DataArray::getDataSize()
RT:{
RT: return 5;
RT:}
RT::----data_size=5
RT:int DataArray::getData(0)
RT:{
RT: if(index >= 0 && index < m_dataSize)
RT: {
RT: return m_buffer[0]RT: }
RT:}
RT:int DataArray::getData(1)
RT:{
RT: if(index >= 0 && index < m_dataSize)
RT: {
RT: return m_buffer[1]RT: }
RT:}
RT:int DataArray::getData(2)
RT:{
RT: if(index >= 0 && index < m_dataSize)
RT: {
RT: return m_buffer[2]RT: }
RT:}
RT:int DataArray::getData(3)
RT:{
RT: if(index >= 0 && index < m_dataSize)
RT: {
RT: return m_buffer[3]RT: }
RT:}
RT:int DataArray::getData(4)
RT:{
RT: if(index >= 0 && index < m_dataSize)
RT: {
RT: return m_buffer[4]RT: }
RT:}
RT:----total=10
可以很明顯的看出:讀和寫之間沒有任何交叉,當然這時的結果就是對的了。
代碼
首先在46行創建QMutex對象。
CreatDataTask從48行到68行,是一個內嵌類。57行增加了一個引用類型的私有數據成員m_mutex。實際的對象是在73行調用51行的構造函數時傳進來的。在62行訪問數據之前調用lock方法,在65行訪問數據結束后調用unlock方法。
讀數據是在主函數中進行,它也是一個線程。同樣地,訪問數據之前調用lock方法,訪問數據之后調用unlock方法。
“QT互斥量怎么實現”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。