进程间通信

一. 实现pipe/msgqueue/sems/shm相关代码

1.实现pipe

1write()
函数定义:ssize_t write (int fd, const void * buf, size_t count); 
函数说明:write()会把参数buf所指的内存写入count个字节到参数放到所指的文件内。
返回值:如果顺利write()会返回实际写入的字节数。当有错误发生时则返回-1,错误代码存入errno中。
(1write()函数返回值一般无0,只有当如下情况发生时才会返回0write(fp, p1+len, (strlen(p1)-len)中第三参数为0,此时write()什么也不做,只返回0
2read()

函数定义:ssize_t read(int fd, void * buf, size_t count);
函数说明:read()会把参数fd所指的文件传送count 个字节到buf 指针所指的内存中。
返回值:返回值为实际读取到的字节数, 如果返回0, 表示已到达文件尾或是无可读取的数据。若参数count0, 则read()不会有作用并返回0。
注意:read时fd中的数据如果小于要读取的数据,就会引起阻塞。

2消息队列
创建消息队列

int main( void )
{
    int id = msgget(1234,//消息队列的名字
        IPC_CREAT|0644);//创建消息队列
    if ( id == -1 ) perror("msgget"),exit(1);
    printf("msg create ok\n");
}

发送消息

send.c//发送消息

//消息结构
struct msgbuf{
    long channel;//通道号
    char mtext[100];
};

int main( void )
{
    struct msgbuf buf;

    int id = msgget(1234, 0);
    if ( id == -1 )perror("msgget"),exit(1);


    while ( 1 ) {
        printf("channel:");
        scanf("%d", &buf.channel);
        printf("mtext:");
        scanf("%s", buf.mtext);
        if (msgsnd(id, //消息队列标识
            &buf,      //准备发送消息的地址
            strlen(buf.mtext),//消息的长度
            0) == -1)//一般为0
            perror("snd"),exit(1);
        printf("write ok\n");
    }
}

接收消息

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

struct msgbuf{
    long channel;
    char mtext[100];
};

int main( void )
{
    struct msgbuf buf;

    int id = msgget(1234, 0);
    if ( id == -1 )perror("msgget"),exit(1);
    1
    while ( 1 ) {
        int channel;
        printf("读哪个通道的数据? :");
        scanf("%d", &channel);
        memset(&buf, 0x00, sizeof(buf));
        msgrcv(id, 
            &buf,//收数据的地方
            100,//装数据地方的大小,不包括通道号
            channel,//从哪个通道收数据
            0); //一般不研究
        printf("buf.mtext=%s\n", buf.mtext);
    }
}


3.共享内存

  1. 练习ipcs -q/m/s于ipcrm -q/m/s的使用,并总结
  2. 将二元信号量P/V操作,封装成动态/静态库,并分别使用并测试
  3. 调研同步与互斥概念原理,了解生产者消费者原理。
    总结上述内容. 作业以链接形式提交(代码也是在博客中体现).
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值