为了进程相互之间交换数据,引入了进程间通信(IPC )。
常用的机制有:
1 .共享内存段(shared memory segment)。在内存中划分一段公共区域供多个进程共享,以达到在多进程间快速、大量的共享数据。
2 .管道(pipe)是先进先出的单向数据通道,可在相关进程间传递未结构化的数据流。
3. FIFO(即命名管道)是拥有永久名称的管道。
4. 信号量(Semaphore)。允许进程相互同步,主要特点为,避免多个进程共享资源时的冲突。
5 .消息队列(Message queue)。在进程间以队列形式异步传递少量数据,例如消息。
而在UNIX中也有着面向客户/服务器模型而设计的,针对客户和服务器程序提供不同的socket 系统调用。我们通常可以称为套接字。
6. 套接字(Socket)端口式进程通信方式。类似于插槽,针对客户和服务器模型,客户随即申请一个Socket,系统为之分配一个Socket号,双方根据Socket号进行通信。
管道 pipe()举例:
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
int main()
{
intdata_processed;
intfile_pipes[2];
const char some_data[] = "123";
char buffer[BUFSIZ + 1];
pid_tfork_result;
memset(buffer, '\0', sizeof(buffer));
if (pipe(file_pipes) == 0) {
fork_result = fork();
if (fork_result == (pid_t)-1) {
fprintf(stderr, "Fork failure");
exit(EXIT_FAILURE);
}
if (fork_result == 0) {
data_processed = read(file_pipes[0], buffer,
BUFSIZ);
printf("Read %d bytes: %s\n", data_processed,
buffer);
exit(EXIT_SUCCESS);
}
else {
data_processed = write(file_pipes[1], some_data,
strlen(some_data));
printf(“Wrote %d bytes\n”, data_processed);
}
}
exit(EXIT_SUCCESS);
}
if (fork_result == (pid_t)-1) {
fprintf(stderr, "Fork failure");
exit(EXIT_FAILURE);
}
if (fork_result == 0) {
data_processed = read(file_pipes[0], buffer,
BUFSIZ);
printf("Read %d bytes: %s\n", data_processed,
buffer);
exit(EXIT_SUCCESS);
}
else {
data_processed = write(file_pipes[1], some_data,
strlen(some_data));
printf(“Wrote %d bytes\n”, data_processed);
}
}
exit(EXIT_SUCCESS);
}
if (fork_result == (pid_t)-1) {
fprintf(stderr, "Fork failure");
exit(EXIT_FAILURE);
}
if (fork_result == 0) {
data_processed = read(file_pipes[0], buffer,
BUFSIZ);
printf("Read %d bytes: %s\n", data_processed,
buffer);
exit(EXIT_SUCCESS);
}
else {
data_processed = write(file_pipes[1], some_data,
strlen(some_data));
printf(“Wrote %d bytes\n”, data_processed);
}
}
exit(EXIT_SUCCESS);
}