日期:2014-05-16  浏览次数:20715 次

请教:多进程共享内存问题
父进程创建了32个子进程,父进程负责向共享内存写数据,每个子进程都需要读取该共享内存里的数据并发送,问题是,如何实现 当所有子进程都读过该数据后,删除此数据。(不能一次性全删除,因为父进程会不停地写数据,子进程不停地读数据,发数据。每一份数据只需要每个子进程读一遍,所有子进程都读完后,删除。)
下面是父进程创建共享内存的代码。
	 
struct DATA_INFO
{
int iDataLen;
BYTE btData[1024];
};
vector<DATA_INFO> *pSendBufVector;
int shmid=shmget(IPCKEY,39452672,0640|IPC_CREAT|IPC_EXCL);
if(shmid==-1)
{
    printf("shmget error\n");
    return -1;
}
else
{
    printf("shmget ok\n");
}
//将这块共享内存区附加到自己的内存段
pSendBufVector = (vector<DATA_INFO> *)shmat(shmid,NULL,0);
多进程 内存共享

------解决方案--------------------
每份数据设置一个计数值,子进程读完数据就给它+1或者位操作,父进程判断所有子进程都读完就删除数据
------解决方案--------------------
引用:
嗯,多些楼上的回复。这样可以判断是否子进程都读过了,但是麻烦的是pSendBufVector,一边主进程在删除前面的数据,一边别的子进程再向后读取数据。子进程读取数据时,并不知道前面的数据已经被删除了,地址应该跟着变。

可以建32个共享内存不,分别给每个子进程一份独立的数据,这样会不会好处理些?

不是很明白你说的
假如共享内存存放多份数据。子进程下次读取的位置应该和父进程协议好,比如每次偏移多少,或者在上一份数据里面直接有下一份数据的地址信息
------解决方案--------------------
做成环形队列, 使用进程共享锁+条件变量 或者 使用信号量.