неверный дескриптор файла при чтении очереди сообщений posix - PullRequest
0 голосов
/ 14 февраля 2020

Подобные темы существуют, но ни одна из них не помогла. Я получаю ошибку дескриптора файла при чтении с кодом ниже linux. Я также указываю атрибуты очереди при сортировке с флагом O_CREAT. Есть идеи? Спасибо.

#include <stdio.h>
#include <mqueue.h>
#include <pthread.h>
#include <errno.h>
#include <string.h>


#define Log(...) printf(__VA_ARGS__); fflush(stdout)
int error;

void* producer(void* arg)   {
    Log("producer\n");

    mqd_t q = mq_open("/ytm", O_RDWR);
    mq_send(q, "kardeshians", sizeof("kardeshians"), 1);

}


void* consumer(void* arg)    {

    Log("consumer\n");
    char buff[32];
    mqd_t q = mq_open("/ytm", O_RDONLY);
    int prio;

    while(1)    {
        error =  mq_receive(q,buff,sizeof(buff), NULL);
        if(error)   {
            printf("read error %d  %s\n", errno, strerror(errno));
        }
    }

}



int main()  {

    struct mq_attr attr;
    attr.mq_maxmsg = 10;
    attr.mq_msgsize = 32;
    mqd_t queue = mq_open("/ytm", O_CREAT | O_RDWR, 0, &attr);


    pthread_t tid;
    pthread_create(&tid, 0 , producer, 0);
    pthread_create(&tid, 0 , consumer, 0);


    while(1);
}

1 Ответ

0 голосов
/ 14 февраля 2020

Проблема была как с разрешением на выполнение, так и с размером сообщения. После запуска как root и увеличения размера буфера чтения больше, чем mq_msgsize, он работал. Спасибо за предложения по проверке ошибок. Вот рабочий код:

#include <stdio.h>

#include <mqueue.h>
#include <pthread.h>

#include <errno.h>
#include <string.h>


#define Log(...) printf(__VA_ARGS__); fflush(stdout)
int error;

void* producer(void* arg)   {
    Log("producer\n");

    mqd_t q = mq_open("/ytm", O_RDWR);

    if(q == -1)  {
        printf("mq_open error %d  %s\n", errno, strerror(errno));
        exit(0);
    }

   while(1) {
        int retval = mq_send(q, "kardeshians\n", sizeof("kardeshians\n"), 1);

        if(retval == -1)    {
            printf("mq_open error %d  %s\n", errno, strerror(errno));
            exit(0);
        }
   }


}


void* consumer(void* arg)    {

    Log("consumer\n");
    char buff[64];
    mqd_t q = mq_open("/ytm", O_RDONLY);
    int prio;

    while(1)    {
        int retval =  mq_receive(q,buff,sizeof(buff), NULL);
        if(retval ==  -1)   {
            printf("read error %d  %s\n", errno, strerror(errno));
        } else {
            printf("got message : %s", buff);
        }
    }

}



int main()  {

    struct mq_attr attr;
    attr.mq_maxmsg = 10;
    attr.mq_msgsize = 32;
    mq_unlink ("/ytm");
    mqd_t queue = mq_open("/ytm", O_CREAT | O_RDWR, 0, &attr);


    pthread_t tid;
    pthread_create(&tid, 0 , producer, 0);
    pthread_create(&tid, 0 , consumer, 0);


    while(1);
}
...