ftok函数:
系统建立IPC通讯(消息队列、信号量和共享内存)时必须指定一个id值。通常情况下,该id值通过ftok函数得到。
ftok原型:
#include <sys/types.h>
#include <sys/ipc.h>
key_t ftok(const char *fhname, int id);
key_t key;
key=ftok(".",1);//这是将fname设为当前目录
//id是子序号。int型,但是只使用8bit(1-255)
msgctl(msgid,IPC_RMID,NULL);
//消息队列的移除:
一般在UNIX实现中,是将文件的索引节点号取出,前面加上子序号得到key_t的返回值。
如指定文件的索引节点号为65538,换算成16进制为0x010002,指定的id为38,换算成16进制为0x26,则最后key_t返回值为0x26010002
如果要确保key_t值不变,需要确保ftok的文件不被删除,或者不用ftok,指定一个固定key_t值。
获取:
#include <stdio.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
#include <string.h>
// int msgget(key_t key, int msgflg);
// int msgsnd(int msqid, const void *msgp, size_t msgsz, int msgflg);
// ssize_t msgrcv(int msqid, void *msgp, size_t msgsz, long msgtyp,int msgflg);
struct msgbuf {
long mtype;
char mtext[128];
};
int main()
{
struct msgbuf readbuf;
struct msgbuf sendbuf={988,"thankyou send\n"};
key_t key;
key=ftok(".",1);
printf("key=%d\n",key);
int msgid=msgget(key,IPC_CREAT|0777);
//有队列就获取,没有就创建,| 权限可读可写可执行
if(msgid==-1){
printf("get que failuer\n");
}
msgrcv(msgid,&readbuf,sizeof(readbuf.mtext),888,0);
//接收
printf("read from que:%s\n",readbuf.mtext);
msgsnd(msgid,&sendbuf,strlen(sendbuf.mtext),0);
//发送数据
msgctl(msgid,IPC_RMID,NULL);
//消息队列的移除:
return 0;
}
发送:
#include <stdio.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
#include <string.h>
// int msgget(key_t key, int msgflg);
// int msgsnd(int msqid, const void *msgp, size_t msgsz, int msgflg);
// ssize_t msgrcv(int msqid, void *msgp, size_t msgsz, long msgtyp,int msgflg);
struct msgbuf {
long mtype;
char mtext[128];
};
int main()
{
struct msgbuf sendbuf={888,"this is message from quen"};
struct msgbuf readbuf;
key_t key;
key=ftok(".",1);
printf("key=%d\n",key);
int msgid=msgget(key,IPC_CREAT|0777);
//有队列就获取,没有就创建,| 权限可读可写可执行
if(msgid==-1){
printf("get que failuer\n");
}
msgsnd(msgid,&sendbuf,strlen(sendbuf.mtext),0);
//发送数据
msgrcv(msgid,&readbuf,sizeof(readbuf.mtext),988,0);
//接收
printf("return from get:%s",readbuf.mtext);
msgctl(msgid,IPC_RMID,NULL);
//消息队列的移除:
return 0;
}