进程间的通信机制

原创 2013年12月05日 17:37:14

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

 }

 

进程间通信机制有哪些?

进程间的通信方式:    1.管道(pipe)及有名管道(named pipe):     管道是一种半双工的通信方式,数据只能单向流动,而且只能在具有亲缘关系的进程间使用。进程的亲缘关系...
  • qq_26626709
  • qq_26626709
  • 2016年08月14日 20:09
  • 3103

高级进程间通信

1.基于STREAMS的管道 流管道是一个双向(全双工)管道。单个流管道就能向父、子进程提供双向的数据流     1).命名的STREAMS管道 我们可以用fattach函数来在文件系统...
  • tian8126359
  • tian8126359
  • 2013年07月04日 11:31
  • 1040

一文详尽 Android 通信:四大组件之间 & 进程间 & 线程间 & 多个App间

本文大纲 看完本文能收获什么?按目录索引,你可以学习到: 组件间的通信,Activity,fragment,Service, Provider,Receiver 进程间的通信,AIDL 线...
  • ChatHello
  • ChatHello
  • 2017年04月04日 12:16
  • 706

进程间的通信机制

进程通信方式: 进程间通信就是在不同进程之间传播或交换信息,那么不同进程之间存在着什么双方都可以访问的介质呢?进程的用户空间是互相独立的,一般而言是不能互相访问的,唯一的例外是共享内存区。但是,系统...
  • Steven_zgH
  • Steven_zgH
  • 2013年09月25日 22:29
  • 584

从AILD与bindService谈Binder进程间通信原理(上)

从AILD与bindService谈Binder进程间通信原理 彻底弄明白AIDL进程间通信的原理
  • zero9988
  • zero9988
  • 2017年06月23日 14:09
  • 1734

【Linux】进程间通信之共享内存

为什么进程间需要通信? 1、数据传输:一个进程需要将它的数据发送给另一个进程。 2、资源共享:多个进程之间享受同样的资源 3、通知事件:一个进程需要向另一个或另一组进程发送消息,通知它们发生了某种事件...
  • Scenlyf
  • Scenlyf
  • 2016年07月28日 21:04
  • 1931

进程之间的数据传递

  随着我们开发的应用的日益复杂,像以往那样将所有功能坐在一个exe文件中情况越来越少,更多时候是整个应用由若干模块、甚至若干单独的exe文件组成,这就涉及到了模块或进程间的通讯交互问题,本文主要谈谈...
  • leikezhu1981
  • leikezhu1981
  • 2011年05月23日 17:12
  • 3162

linux进程间的通信机制——信号

1.核心理论 信号:在linux中信号是一个古老的进程间的通讯机制,就像古代烽火台所起到的传递信号的作用一样。 信号处理流程 信号通讯机制就分为三步:选择信号→发送信号→处理信号 信号类型 lin...
  • liusirboke
  • liusirboke
  • 2015年11月15日 16:56
  • 208

进程间共享变量

在php中可以实现在进程间共享信息的途径,并保证能快速地访问这些共享数据。有两种方式:shmop 和 System V这两种共享内存扩展方式。   shmop使用的例子: // create k...
  • u010437896
  • u010437896
  • 2013年05月02日 17:38
  • 1379

进程间同步的方法

进程间同步的方法   2010-05-10 01:03:42|  分类: Linux|字号 订阅 进程间通讯(IPC)方法主要有以下几种:        管道/F...
  • jfkidear
  • jfkidear
  • 2012年07月09日 14:59
  • 11859
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:进程间的通信机制
举报原因:
原因补充:

(最多只允许输入30个字)