我正在尝试编写一个C ++程序来删除共享内存段。我知道可以使用
从cmd提示符完成 ipcs -m | awk '{ print $2 }' | xargs ipcrm -m
但是我正在尝试使用C ++来创建一个共享内存垃圾收集器。
想法是删除未附加到任何进程的共享内存段(nattach == 0)或状态== NULL
答案 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); //使用上述代码的示例