Я пытался искать в сети, но существуют едва любые ресурсы. Небольшой пример был бы достаточен.
ОТРЕДАКТИРУЙТЕ я имею в виду, две различных общающиеся друг с другом программы C. Одна программа должна отправить "Привет", и другой должен получить его. Что-то как этот.
Обычный канал может соединять только два связанных процесса. Он создается процессом и исчезнет, когда его закроет последний процесс.
Именованный канал , также называемый FIFO из-за своего поведения, может использоваться для соединения двух несвязанных процессов и существует независимо от процессов; это означает, что он может существовать, даже если его никто не использует. FIFO создается с помощью библиотечной функции mkfifo ()
.
writer.c
#include <fcntl.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <unistd.h>
int main()
{
int fd;
char * myfifo = "/tmp/myfifo";
/* create the FIFO (named pipe) */
mkfifo(myfifo, 0666);
/* write "Hi" to the FIFO */
fd = open(myfifo, O_WRONLY);
write(fd, "Hi", sizeof("Hi"));
close(fd);
/* remove the FIFO */
unlink(myfifo);
return 0;
}
reader.c
#include <fcntl.h>
#include <stdio.h>
#include <sys/stat.h>
#include <unistd.h>
#define MAX_BUF 1024
int main()
{
int fd;
char * myfifo = "/tmp/myfifo";
char buf[MAX_BUF];
/* open, read, and display the message from the FIFO */
fd = open(myfifo, O_RDONLY);
read(fd, buf, MAX_BUF);
printf("Received: %s\n", buf);
close(fd);
return 0;
}
Примечание. Для простоты в приведенном выше коде не было проверки ошибок.
Из Создание труб в C, здесь показано, как форкнуть программу, чтобы использовать трубу. Если вы не хотите использовать fork(), вы можете использовать именованные трубы.
Кроме того, вы можете получить эффект от prog1 | prog2
, отправив вывод prog1
в stdout и прочитав из stdin
в prog2
. Вы также можете читать stdin, открыв файл с именем /dev/stdin
(но не уверен в переносимости этого).
/*****************************************************************************
Excerpt from "Linux Programmer's Guide - Chapter 6"
(C)opyright 1994-1995, Scott Burkett
*****************************************************************************
MODULE: pipe.c
*****************************************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/types.h>
int main(void)
{
int fd[2], nbytes;
pid_t childpid;
char string[] = "Hello, world!\n";
char readbuffer[80];
pipe(fd);
if((childpid = fork()) == -1)
{
perror("fork");
exit(1);
}
if(childpid == 0)
{
/* Child process closes up input side of pipe */
close(fd[0]);
/* Send "string" through the output side of pipe */
write(fd[1], string, (strlen(string)+1));
exit(0);
}
else
{
/* Parent process closes up output side of pipe */
close(fd[1]);
/* Read in a string from the pipe */
nbytes = read(fd[0], readbuffer, sizeof(readbuffer));
printf("Received string: %s", readbuffer);
}
return(0);
}
Что одна программа пишет в стандартный вывод может быть прочитан другим через стандартный ввод. Так просто, используя c, напишите prog1
, чтобы что-то напечатать, используя printf ()
и prog2
, чтобы прочитать что-нибудь с помощью scanf ()
. Затем просто запустите
./prog1 | ./prog2
сначала попросите программу 1 записать строку в стандартный вывод (как если бы вы хотели, чтобы она отображалась на экране). тогда вторая программа должна прочитать строку из стандартного ввода, как если бы пользователь печатал с клавиатуры. затем вы запускаете:
program_1 | program_2
int main()
{
char buff[1024] = {0};
FILE* cvt;
int status;
/* Launch converter and open a pipe through which the parent will write to it */
cvt = popen("converter", "w");
if (!cvt)
{
printf("couldn't open a pipe; quitting\n");
exit(1)
}
printf("enter Fahrenheit degrees: " );
fgets(buff, sizeof (buff), stdin); /*read user's input */
/* Send expression to converter for evaluation */
fprintf(cvt, "%s\n", buff);
fflush(cvt);
/* Close pipe to converter and wait for it to exit */
status=pclose(cvt);
/* Check the exit status of pclose() */
if (!WIFEXITED(status))
printf("error on closing the pipe\n");
return 0;
}
Важные шаги в этой программе:
popen ()
вызов, который устанавливает связь между дочерним процессом и конвейером в родительском. fprintf ()
, который использует канал как обычный файл для записи в стандартный ввод дочернего процесса или чтения из его стандартного вывода. pclose ()
, который закрывает канал и вызывает завершение дочернего процесса.