利用消息队列实现服务器客户端的通信

1.server.c

#include"utili.h"

#define SND_TYPE 200
#define RCV_TYPE 100
typedef struct MsgType
{
    long msg_type;
    char msg_buf[MAX_MSG_LEN];
}MsgType;

int main(int argc, char const* argv[])
{
    key_t msg_key = ftok("mymsg", 0xff);
    if(msg_key == -1)
    {
        perror("ftok");
        exit(EXIT_FAILURE);
    }

    int msg_id = msgget(msg_key, IPC_CREAT | 0755);
    if(msg_id == -1)
    {
        perror("msgget");
        exit(EXIT_FAILURE);
    }

    MsgType msg;
    while(1)
    {
        msg.msg_type = SND_TYPE;
        printf("Ser:>");
        scanf("%s", msg.msg_buf);
        msgsnd(msg_id, &msg, strlen(msg.msg_buf)+1, 0);

        msgrcv(msg_id, &msg, MAX_MSG_LEN, RCV_TYPE, 0);
        printf("Cli:>%s\n", msg.msg_buf);
    }

    return 0;
}

2.client.c

#include"utili.h"

#define SND_TYPE 100
#define RCV_TYPE 200
typedef struct MsgType
{
    long msg_type;
    char msg_buf[MAX_MSG_LEN];
}MsgType;

int main(int argc, char const* argv[])
{
    key_t msg_key = ftok("mymsg", 0xff);
    if(msg_key == -1)
    {
        perror("ftok");
        exit(EXIT_FAILURE);
    }

    int msg_id = msgget(msg_key, 0);
    if(msg_id == -1)
    {
        perror("msgget");
        exit(EXIT_FAILURE);
    }

    MsgType msg;
    while(1)
    {
        msgrcv(msg_id, &msg, MAX_MSG_LEN, RCV_TYPE, 0);
        printf("Ser:>%s\n", msg.msg_buf);
        msg.msg_type = SND_TYPE;
        printf("Cli:>");
        scanf("%s", msg.msg_buf);
        msgsnd(msg_id, &msg, strlen(msg.msg_buf)+1, 0);

     //   msgrcv(msg_id, &msg, MAX_MSG_LEN, RCV_TYPE, 0);
     //   printf("Ser:>%s\n", msg.msg_buf);
    }

    return 0;
}

3.utili.h

#include<stdio.h>
#include<unistd.h>
#include<sys/ipc.h>
#include<sys/msg.h>
#include<string.h>
#include<stdlib.h>

#define MAX_MSG_LEN 256

4.Makefile

ALL:server client
server:server.c
    gcc server.c -o server
client:client.c
    gcc client.c -o client
clean:
    /bin/rm -f server client

测试
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值