免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2711 | 回复: 7
打印 上一主题 下一主题

初学共享内存,有疑问,请帮我看看 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-04-28 11:23 |只看该作者 |倒序浏览
我想建一段共享内存,打印出它的地址。
但是编译执行后报错:shmat error:Invalid argument
请问为什么?
代码如下:
#include <stdio.h>
#include <errno.h>
#include <sys/shm.h>

int
main(int argc, char **argv) {
    key_t  tRet;
    int    iRet;
    int    iShmID;
    char   sMsg[1024+1];
    char   *psShm;

    tRet = Ftok(".", 9, sMsg);
    if(tRet < 0) {
        printf("Ftok error:%s \n", sMsg);
        return(tRet);
    }

    iShmID = shmget(tRet, 256, IPC_CREAT|IPC_EXCL|SHM_R|SHM_W);
    if(iRet < 0) {
        printf("shmget error:%s \n", strerror(errno));
        return(iRet);
    }

    psShm = shmat(iShmID, 0, 0);
    if(psShm == (void *)(-1)) {
        printf("shmat error:%s \n", strerror(errno));
        return(-1);
    }
    printf("[%x]--[%x]\n", psShm, psShm+256);

    iRet = shmdt((void *)psShm);
    if(iRet < 0) {
        printf("shmdt error:%s \n", strerror(errno));
        return(iRet);
    }

    iRet = shmctl(iShmID, IPC_RMID, 0);
    if(iRet < 0) {
        printf("shmctl error:%s \n", strerror(errno));
        return(iRet);
    }

    return 0;
}

论坛徽章:
0
2 [报告]
发表于 2006-04-28 11:45 |只看该作者
没有Ftok这个函数


是ftok吧,

论坛徽章:
0
3 [报告]
发表于 2006-04-28 12:14 |只看该作者

回复 2楼 stiandao 的帖子

是的。
key_t
Ftok(const char *psPath, int iId, char *psMsg) {
    key_t   tRet;
    char    sPath[1024+1];

    if((psPath == NULL) || (psMsg == NULL)) {
        printf("Ftok error: parameter error \n");
        exit(-1);
    }

    memset(sPath, 0x00, sizeof(sPath));
    memset(psMsg, 0x00, sizeof(psMsg));
    strcpy(sPath, psPath);
    tRet = ftok(sPath, iId);
    if(tRet < 0) {
        sprintf(psMsg, "ftok error: %s", strerror(errno));
        return(tRet);
    }
    return(tRet);
}

论坛徽章:
0
4 [报告]
发表于 2006-04-28 12:15 |只看该作者

回复 1楼 anfield_xu 的帖子

应该是shmat函数的问题,是不是参数类型不对呀?
请帮帮我

论坛徽章:
0
5 [报告]
发表于 2006-04-28 14:56 |只看该作者

  1. if(iRet < 0) {
  2.         printf("shmget error:%s \n", strerror(errno));
  3.         return(iRet);
  4.     }
复制代码

改成:

  1. if(iShmID < 0) {
  2.         printf("shmget error:%s \n", strerror(errno));
  3.         return(iRet);
  4.     }
复制代码



  1. #include <stdio.h>
  2. #include <errno.h>
  3. #include <sys/shm.h>

  4. key_t
  5. Ftok(const char *psPath, int iId, char *psMsg) {
  6.     key_t   tRet;
  7.     char    sPath[1024+1];

  8.     if((psPath == NULL) || (psMsg == NULL)) {
  9.         printf("Ftok error: parameter error \n");
  10.         exit(-1);
  11.     }

  12.     memset(sPath, 0x00, sizeof(sPath));
  13.     memset(psMsg, 0x00, sizeof(psMsg));
  14.     strcpy(sPath, psPath);
  15.     tRet = ftok(sPath, iId);
  16.     if(tRet < 0) {
  17.         sprintf(psMsg, "ftok error: %s", strerror(errno));
  18.         return(tRet);
  19.     }
  20.     return(tRet);
  21. }

  22. int
  23. main(int argc, char **argv) {
  24.     key_t  tRet;
  25.     int    iRet;
  26.     int    iShmID;
  27.     char   sMsg[1024+1];
  28.     char   *psShm;

  29.     tRet = Ftok(".", 9, sMsg);
  30.     if(tRet < 0) {
  31.         printf("Ftok error:%s \n", sMsg);
  32.         return(tRet);
  33.     }

  34.     iShmID = shmget(tRet, 256, IPC_CREAT|SHM_R|SHM_W);
  35.     if(iShmID < 0) {
  36.         printf("shmget error:%s \n", strerror(errno));
  37.         return(iRet);
  38.     }

  39.     psShm = shmat(iShmID, 0, 0);
  40.     if(psShm == (void *)(-1)) {
  41.         printf("shmat error:%s \n", strerror(errno));
  42.         return(-1);
  43.     }
  44.     printf("[%x]--[%x]\n", psShm, psShm+256);

  45.     iRet = shmdt((void *)psShm);
  46.     if(iRet < 0) {
  47.         printf("shmdt error:%s \n", strerror(errno));
  48.         return(iRet);
  49.     }

  50.     iRet = shmctl(iShmID, IPC_RMID, 0);
  51.     if(iRet < 0) {
  52.         printf("shmctl error:%s \n", strerror(errno));
  53.         return(iRet);
  54.     }

  55.     return 0;
  56. }
复制代码

论坛徽章:
0
6 [报告]
发表于 2006-04-28 15:09 |只看该作者

回复 5楼 westgarden 的帖子

谢谢,我太粗心了,呵呵。

我把:
iShmID = shmget(tRet, 256, IPC_CREAT|IPC_EXCL|SHM_R|SHM_W);
    if(iRet < 0) {
        printf("shmget error:%s \n", strerror(errno));
        return(iRet);
    }
改为了:
iShmID = shmget(tRet, 256, IPC_CREAT|SHM_R|SHM_W);
    if(iShmID < 0) {
        printf("shmget error:%s \n", strerror(errno));
        return(iRet);
    }

编译运行还是报错:shmget error:Permission denied

是不是权限的问题呀?

论坛徽章:
0
7 [报告]
发表于 2006-04-28 15:49 |只看该作者
原帖由 anfield_xu 于 2006-4-28 15:09 发表
谢谢,我太粗心了,呵呵。

我把:
iShmID = shmget(tRet, 256, IPC_CREAT|IPC_EXCL|SHM_R|SHM_W);
    if(iRet < 0) {
        printf("shmget error:%s \n", strerror(errno));
        r ...


你最好把IPC_EXCL去掉,
不然会提示"File exists"。

至于
编译运行还是报错:shmget error:Permission denied
是不是权限的问题呀?

换个生成键值的路径看看或
用ipcs及ipcrm查看及删除shm 的id。
如果删不掉,估计就是权限问题了。

论坛徽章:
0
8 [报告]
发表于 2006-04-28 17:03 |只看该作者

回复 7楼 westgarden 的帖子

好了,解决了。谢谢大家。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP