作者cty222 (纵裕)
看板LinuxDev
标题Re: [问题] 关於多process执行顺序 (QT)
时间Tue Dec 18 00:24:09 2012
※ 引述《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
1F:→ KevinR:volatile... 12/20 19:21