使用C ++程序删除unix共享内存段

时间:2012-03-01 20:03:25

标签: c++ unix shared-memory inter-process-communicat ipcs

我正在尝试编写一个C ++程序来删除共享内存段。我知道可以使用

从cmd提示符完成

ipcs -m | awk '{ print $2 }' | xargs ipcrm -m

但是我正在尝试使用C ++来创建一个共享内存垃圾收集器。

想法是删除未附加到任何进程的共享内存段(nattach == 0)或状态== NULL

4 个答案:

答案 0 :(得分:5)

我终于得到了自己问题的答案。它可以使用shmctl标志来完成。 shmctl(0,SHM_INFO,&shm_info);给出了当前存在的细分数量。

shmctl(i , SHM_STAT , &shm_segment)给出了段ID

也可以通过shm_segment.shm_id

访问它
#include <sys/shm.h>     

int delete_segment(int seg_id){
    if ((shmctl(seg_id,IPC_RMID,0))==-1){
    std::cout<<" ERROR(C++)with shmctl(IPC_RMID): "<<strerror(errno)<<std::endl;
    return -1;
    }else//on success
        return 0;
}

void clean_segments(){

    struct shmid_ds shm_info;
    struct shmid_ds shm_segment;
    int max_id = shmctl(0,SHM_INFO,&shm_info);
    if (max_id>=0){
        for (int i=0;i<=max_id;++i) {
                int shm_id = shmctl(i , SHM_STAT , &shm_segment);
                if (shm_id<=0)
                    continue;
                else if (shm_segment.shm_nattch==0){
                    delete_segment(shm_id);
                }
        }
    }
    return result;
}

答案 1 :(得分:2)

根据ipcrm的{​​{3}},它会调用source code

shmctl(id, IPC_RMID, NULL)

答案 2 :(得分:1)

我建议执行strace ipcrm -m <your-arguments>并查看它执行的系统调用。在大多数情况下应该是足够的(至少它会指向正确的方向),如果不是 - 请查看 ipcrm 的源代码。我很确定你不需要任何特殊权限(我的系统上的ipcrm没有设置SUID或SGID位)。

答案 3 :(得分:0)

以下代码使用I:

    void clean_segments(int startId, int endId) {
    for (int i=startId; i<=endId; ++i) {
        struct shmid_ds shm_segment;
        int shm_id = shmctl(i, SHM_STAT, &shm_segment);
        delete_segment(shm_id);
        printf("Segment %d has been deleted\n", shm_id);
    }}

clean_segments(1146894,6357160); //使用上述代码的示例