进程间通信

一. 实现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 
#include 
#include 
#include 
#include 
#include 

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. 调研同步与互斥概念原理,了解生产者消费者原理。
    总结上述内容. 作业以链接形式提交(代码也是在博客中体现).

你可能感兴趣的:(linux)