mq_unlink

本文详细介绍了mq_unlink函数的功能及使用方法。该函数用于销毁一个消息队列,并且即使仍有进程引用该队列,销毁操作也会被延迟执行直至所有引用被关闭。文章还提供了错误处理说明及使用示例。

NAME

mq_unlink - 销毁一个消息队列 (REALTIME)

SYNOPSIS

#include <mqueue.h>

int mq_unlink(const char *name);

DESCRIPTION

函数 mq_unlink() 会从内核中删除名为name的消息队列.

如果该函数被调用了,但是仍然有进程已经打开了这个消息队列,那么这个消息队列的销毁会被推迟到所有的引用都被关闭时执行.

并且函数 mq_unlink() 不需要阻塞到所有的引用都被关闭为止,它会立即返回.

函数 mq_unlink()调用成功后, 如果在随后调用 mq_open() 时重用这个消息队列名字,效果就像这个名字的消息队列不存在,

如果没有设置O_CREAT标志,函数mq_open() 会返回失败,否则会创建一个新的消息队列.

PARAMETERS

name

参数 name 是一个指向消息队列名字的指针.

名字的形式是 "/somename",是一个以NULL结尾的字符串,字符串的最大长度为NAME_MAX。

消息队列名字的第一个字符必须是"/",并且之后的字符中不允许出现"/"

  

RETURN VALUE

如果函数执行成功, 函数返回0

如果函数执行失败,函数返回 -1 并且设置errno,errno的种别详见下面的ERRORS一节.

 

ERRORS

[EACCES]

没有权限删除指定的消息队列.

[ENOENT]

指定的消息队列不存在.

[ENAMETOOLONG]

参数 name 的长度超过系统定义的最大长度.

在不支持XSI系统中,name 的长度超过了 {_POSIX_PATH_MAX},在支持XSI系统中,name 的长度超过了 {_XOPEN_PATH_MAX};或者

在不支持XSI系统中,某一级路径的长度超过了 {_POSIX_NAME_MAX},在支持XSI系统中,某一级路径的长度超过了 {_XOPEN_NAME_MAX};

EXAMPLES

 

 

转载于:https://www.cnblogs.com/LubinLew/p/POSIX-mq_unlink.html

#include <stdio.h> #include <stdlib.h> #include <stdbool.h> #include <string.h> #include <sys/wait.h> #include <sys/types.h> #include <sys/stat.h> #include <errno.h> #include <unistd.h> // for execlp #include <mqueue.h> // for mq #include "settings.h" #include "messages.h" char client2dealer_name[30]; int groupnumber = 16; pid_t processID; mqd_t Req_queue_X; MQ_REQUEST_MESSAGE req; int main (int argc, char * argv[]) { struct mq_attr attr; attr.mq_maxmsg = MQ_MAX_MESSAGES; attr.mq_msgsize = sizeof (MQ_REQUEST_MESSAGE); sprintf (client2dealer_name, "/Req_queue_%d", groupnumber); mq_unlink(client2dealer_name); Req_queue_X = mq_open (client2dealer_name, O_RDONLY | O_CREAT | O_EXCL, 0600, &attr); if(Req_queue_X == -1) { perror("Channel creation failed!"); } getattr(Req_queue_X); processID = fork(); if (processID < 0) { perror("fork() failed"); exit (1); } else if (processID == 0) { // child-stuff execlp("./client", "client", client2dealer_name, NULL); perror("execlp failed"); exit (0); } while (1) { int status; pid_t result = waitpid(processID, &status, WNOHANG); // Non-blocking check if (result > 0) { printf("Client terminated\n"); break; } ssize_t size = mq_receive(Req_queue_X, (char*)&req, sizeof(MQ_REQUEST_MESSAGE), 0); if (size == -1) { perror("Receiving failed \n"); } else if ( size == sizeof(MQ_REQUEST_MESSAGE)) { if (req.serv_type == 1 || req.serv_type == 2) { printf("Received message with id %d, type %d and value %d\n", req.req_id, req.serv_type, req.input); } else if (req.serv_type == 0) { printf("...\n"); } } else { perror("mq_receive failed partially \n"); } sleep(1); printf("I'm still alive \n"); } printf("loop ends \n"); waitpid(processID, NULL, 0); mq_close(Req_queue_X); mq_unlink(client2dealer_name); } 帮我分析下问题在哪里
03-14
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值