msgsnd/msgrcv 发生奇怪的行为

Strange behavior occuring with msgsnd/msgrcv

我有两个不同的程序:

第一个,基本上是无限循环地在消息队列上调用 msgrcv 并在它收到任何东西时打印,在 C++ 中:

//foo1.cpp
#include <iostream>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>

typedef struct MessageBuffer {
        long mtype;
        char mtext[255];
} MessageBuffer;

int main() {
    key_t key = ftok("/tmp/toto1", 'b');
    int messageQueue = msgget(key, IPC_CREAT|0666);
    while (true) {
        MessageBuffer message;
        int ret = -1;
        while(ret < 0) {
            usleep(1000000);
            ret = msgrcv(messageQueue, (void*) (&message), sizeof(MessageBuffer)-sizeof(long), 0, 0);
        }
        std::cout << "message is:" << message.mtext << std::endl;
        std::cout << "ret is:" << ret << std::endl;
    }
    return 0;
}

编译为:g++ foo1.cpp -o foo1

由于 msgsnd,另一个只是将消息发送到同一个消息队列,在 C:

//foo2.c
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
#include <string.h>

typedef struct MessageBuffer {
        long mtype;
        char mtext[255];
} MessageBuffer;

int main() {
    key_t key = ftok("/tmp/toto1", 'b');
    int messageQueue = msgget(key, IPC_CREAT|0666);
    MessageBuffer messageToSend;
    //MessageBuffer anOtherMessage; <- problem is here
    strcpy(messageToSend.mtext, "foo message");
    msgsnd(messageQueue, (void*) (&messageToSend), sizeof(MessageBuffer)-sizeof(long), 0);

    return 0;
}

编译:gcc foo2.cpp -o foo2

事实上,一切正常,我可以在foo1的控制台中看到它收到了foo2发送的消息。但是如果我取消注释 foo2.c 中的行,它将不再起作用,foo1 不会收到任何消息。

有人对此有解释吗?

我在 Ubuntu 12.04。 gcc 和 g++ 4.6.3

您忘记检查 return 值并初始化 mtype(必须为正数)。
初始化失败 mtype 意味着您的程序的行为在这两种情况下都未定义。
(它可能是非正数 偶然 当你声明另一个变量时。)

您还向函数传递了过大的大小。

这应该有效:

MessageBuffer messageToSend = {1};
MessageBuffer anOtherMessage = {1};
strcpy(messageToSend.mtext, "foo message");
int result = msgsnd(messageQueue, &messageToSend, sizeof(messageToSend.mtext), 0);
if (result < 0)
{
    /* Handle the error. */
}