Re: [問題] 關於多process執行順序 (QT)
※ 引述《cty222 (縱裕)》之銘言:
: 好像寫的不清不楚...
: 在多寫一些看能不能表達清楚...
: ※ 引述《leolarrel (真.粽子無雙)》之銘言:
: 簡單的說我是直接將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++);也無法
: : 我想幫你,但是我得先弄董你寫的那個..虛擬碼,sorry
: : 有關兩個行程要 hand shake , 其實用一個信號/mutex 來進行同步會比較好.
: 其實我主要是想要在一開始的時候雙方程式互相知道對方的pid
: 想說宣告一個共享的陣列把所有程式的pid照著自訂的規矩依序放入
: 之後好發signal
: 然後這是在試驗的時候發生的而外問題
: 兩個C code 都可以work
: 但其中一個換成QT就"一定"會卡在第一個判斷
: 感覺有點奇怪
: 感謝^ ^
痾
你的C code 虛擬碼,*share 初始值是0 ,接下來你的while判斷*share 要等於1才會執行
printf.可是,你說C code 那邊會一直印 0 , 這.....
: 其實我主要是想要在一開始的時候雙方程式互相知道對方的pid
: 想說宣告一個共享的陣列把所有程式的pid照著自訂的規矩依序放入
: 之後好發signal
所以,依字面上的了解,你會有一塊共享記憶體,不只一個程式會同時寫入這個記憶體,
這樣理解對嗎?
如果對,你最後還是不能使用虛擬碼所表示的方式來進行同步化作業,會死得很難看的
同步化作業,要使用 信號機/mutx/鎖 這幾樣技術才是根本解決方法
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 118.163.30.15
討論串 (同標題文章)
LinuxDev 近期熱門文章
PTT數位生活區 即時熱門文章