Re: [問題] 關於多process執行順序 (QT)

看板LinuxDev作者 (縱裕)時間12年前 (2012/12/18 00:24), 編輯推噓0(001)
留言1則, 1人參與, 最新討論串5/6 (看更多)
※ 引述《leolarrel (真.粽子無雙)》之銘言: : ※ 引述《cty222 (縱裕)》之銘言: : : 好像寫的不清不楚... : : 在多寫一些看能不能表達清楚... : : 簡單的說我是直接將C code的共享記憶體寫法放進QT裡出了問題 : : 以下為共用碼 : : int main(void){ : : int shmid; : : int *share ; : : shmid = shmget(key,sizeof(int),IPC_CREAT|0644); : : share = (int *)shmat( shmid, NULL, 0 ) ; : : C code QT code : : 1. *share = 0 ; | *share=0; : : | 2. while(*share!=1){ | while(*share!=2){ : : printf("%d\n"*share);| *share = 1 ; : : } | sleep(1); <-----問題點 : : | } : : 3. *share=2; | *share=getpid(); : : | : : 4. while(*share==2); | return *share; : : return *share | : : 大致上應該是這樣吧 : : 簡單的說就是上敘C code的部份會一直print "0" : : 除非我在QT code加入sleep(1); : : 用for(i=0;i<100;i++);也無法 : : 其實我主要是想要在一開始的時候雙方程式互相知道對方的pid : : 想說宣告一個共享的陣列把所有程式的pid照著自訂的規矩依序放入 : : 之後好發signal : : 然後這是在試驗的時候發生的而外問題 : : 兩個C code 都可以work : : 但其中一個換成QT就"一定"會卡在第一個判斷 : : 感覺有點奇怪 : : 感謝^ ^ : 痾 : 你的C code 虛擬碼,*share 初始值是0 ,接下來你的while判斷*share 要等於1才會執行 : printf.可是,你說C code 那邊會一直印 0 , 這..... 對...我打錯了 : : 其實我主要是想要在一開始的時候雙方程式互相知道對方的pid : : 想說宣告一個共享的陣列把所有程式的pid照著自訂的規矩依序放入 : : 之後好發signal : 所以,依字面上的了解,你會有一塊共享記憶體,不只一個程式會同時寫入這個記憶體, : 這樣理解對嗎? 對的 : 如果對,你最後還是不能使用虛擬碼所表示的方式來進行同步化作業,會死得很難看的 : 同步化作業,要使用 信號機/mutx/鎖 這幾樣技術才是根本解決方法 感謝指點 所以應該要用mutx去鎖... 上了一課 不過我還是不知道為何會出現我原本想問的問題 就*share=1一直寫不進去 只有讓他睡才行 是優先權的問題嗎?(感覺也不像...) 另外有個問題也想問 因為後來決定用QT 的Dbus function來寫 目前是 main process 發signal到 client process 已經建好了 如果我想要client 發signal到 main 是要再多建一個反向的bus連結嗎? (因為硬體中斷會打到client端 client做好中斷副程式後要跟main講它做了什麼...) ^^" -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 118.169.130.149

12/20 19:21, , 1F
volatile...
12/20 19:21, 1F
文章代碼(AID): #1GpqSiNC (LinuxDev)
討論串 (同標題文章)
文章代碼(AID): #1GpqSiNC (LinuxDev)