我正在开发OpenSuse 42.3 Leap。这是我第一次接触Unix消息队列,我在打开新队列时遇到了一些基本问题。我最初的问题是我无法打开两个队列,但经过几次尝试后我将问题简化为这种奇怪的行为:
如果我编译并运行它
#include<stdio.h>
#include <mqueue.h>
int main() {
// printf("Hello world!\n");
/* create queue */
char *q_name = "/myQueue";
mqd_t desc = mq_open(q_name, O_RDWR | O_CREAT);
if(desc == (mqd_t) -1)
perror("Error in mq_open");
printf("We have opened %d\n", desc);
/* close descriptor and unlink name */
if (mq_close(desc)) perror("Error in close:");
if (mq_unlink(q_name)) perror("Error in unlink:");
return 0;
}
它适用于标准输出:
We have opened 3
队列正确关闭,我可以重新运行它没有错误。
但如果我取消注释该行
printf("Hello world!\n");
它显然仍然正确编译但运行时输出
Hello world!
Error in mq_open: Invalid argument
We have opened -1
Error in close:: Bad file descriptor
Error in unlink:: No such file or directory
如果不是简单的'Hello world!我试着打印:
printf("Hello world! My pid = %d\n", getpid());
然后而不是Invalid argument
错误
Error in mq_open: Bad address
被生产。
知道为什么这个简单的printf
崩溃队列开放吗?
从mq_open手册页:
如果在oflag中指定了O_CREAT,则必须提供另外两个参数。 [...]
您不提供它们,因此您有未定义的行为。似乎发生的事情是,缺失的参数是从内存中的某个位置获取的,并且根据您之前的程序执行的操作会发生什么不同。