管道读写
//写入
#include <sys/types.h>
#include <sys/wait.h>
#include <stdlib.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <errno.h>
#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <time.h>
int main()
{
//1.创建有名管道
int mkfifo_ret = mkfifo("/home/gec/sys_log_fifo",0777);
if(mkfifo_ret == -1)
if(errno != 17)
{
perror("creat fifo failed");
return -1;
}
}
//2.打开管道文件
int fifo_fd = open("/home/gec/sys_log_fifo",O_RDWR);
if(-1 == fifo_fd)
{
perror("open fifo failed");
return -1;
}
//3.往管道里写
char *buf = malloc(100);
while(1)
{
memset(buf,0,100);
//把进程号拼接到buf里面
//时间
time_t local_time;
time(&local_time);
char *real_time = ctime(&local_time);
snprintf(buf,100,"pid = %d,time = %s",getpid(),real_time);
printf("%s",buf);
sleep(1);
write(fifo_fd,buf,strlen(buf));
}
}
//读取
#include <sys/types.h>
#include <sys/wait.h>
#include <stdlib.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <errno.h>
#include <stdio.h>
#include <string.h>
#include <unistd.h>
int main()
{
//往管道里读,把读到的内容写到txt文件里
//1.创建有名管道
int mkfifo_ret = mkfifo("/home/gec/sys_log_fifo",0777);
if(mkfifo_ret == -1)
{
if(errno != 17)
{
perror("creat fifo failed");
return -1;
}
}
//1.打开管道文件
int fifo_fd = open("/home/gec/sys_log_fifo",O_RDWR);
if(-1 == fifo_fd)
{
perror("open fifo failed");
return -1;
}
//2.创建txt文件并打开
int log_fd = open("./log.txt",O_RDWR | O_CREAT,0777);
if(-1 == log_fd)
{
perror("creat log failed");
return -1;
}
//往管道读
char *buf = malloc(100);
while(1)
{
memset(buf,0,100);
read(fifo_fd,buf,100);
write(log_fd,buf,strlen(buf));
}
}