进程间的通信机制

为了进程相互之间交换数据,引入了进程间通信(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);

 }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值