一. 实现pipe/msgqueue/sems/shm相关代码
1.实现pipe
1、write()
函数定义:ssize_t write (int fd, const void * buf, size_t count);
函数说明:write()会把参数buf所指的内存写入count个字节到参数放到所指的文件内。
返回值:如果顺利write()会返回实际写入的字节数。当有错误发生时则返回-1,错误代码存入errno中。
(1)write()函数返回值一般无0,只有当如下情况发生时才会返回0:write(fp, p1+len, (strlen(p1)-len)中第三参数为0,此时write()什么也不做,只返回0。
2、read()
函数定义:ssize_t read(int fd, void * buf, size_t count);
函数说明:read()会把参数fd所指的文件传送count 个字节到buf 指针所指的内存中。
返回值:返回值为实际读取到的字节数, 如果返回0, 表示已到达文件尾或是无可读取的数据。若参数count 为0, 则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.共享内存
- 练习ipcs -q/m/s于ipcrm -q/m/s的使用,并总结
- 将二元信号量P/V操作,封装成动态/静态库,并分别使用并测试
- 调研同步与互斥概念原理,了解生产者消费者原理。
总结上述内容. 作业以链接形式提交(代码也是在博客中体现).