作者leolarrel (真.粽子无双)
看板LinuxDev
标题Re: [问题] 关於多process执行顺序 (QT)
时间Mon Dec 17 20:12:08 2012
※ 引述《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