进程间的通信机制

原创 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);

 }

 

相关文章推荐

nginx进程间的通信机制源码分析(一)----共享内存

共享内存是linux下提供的最基本的进程间通信方法,它通过mmap或者shmget系统调用在内存中创建了一块连续的线性地址空间,而通过munmap和shmdt系统调用可以释放这块内存.使用共享内存的好...

Chromium进程间的通信机制浅析(android版本)(三)

部分内容来源于本文:http://blog.csdn.net/qq295445028/article/details/7993051 一、   消息格式 如果说,多线程模式下,对数据的访问开销...

Chromium进程间的通信机制浅析(android版本)(一)

一、   综述 Chromium的多进程模型意味着会有频繁的进程间通信,其中主要的IPC方式是命名管道。在遵循posix标准的操作系统中,通过UNIX域套接字来实现命名管道。每个render进程都会...

Android开发知识(三)Android进程间Binder通信机制的源码分析(上)

AIDL,全称名为:Android Interface Definition Language。它是安卓中一种跨进程通信的实现方式,使得不同进程不同应用之间可以保持通信。 本篇内容为基础使用篇,下面...
  • lc_miao
  • lc_miao
  • 2017年07月24日 16:29
  • 8214

nginx源码分析1———进程间的通信机制一(信号量)

nginx源码分析1———进程间的通信机制一(信号量)nginx源码分析1进程间的通信机制一信号量相关介绍 相关系统调用 相关结构 初始化 加锁 解锁 销毁相关介绍nginx采用信号量辅助原子变量实现...

Linux与android进程间的通信及android Binder机制详解

关于进程之间的通信又很多种方式,不同的方式适用于不同的场景。 1.管道(pipe) 特点:单向的,具有“读取”端和“写入”端,容量有限。 实例: 2.Signal  3.Trace 跟踪 以上三种...

从AIDL开始谈Android进程间Binder通信机制

本文首先概述了Android的进程间通信的Binder机制,然后结合一个AIDL的例子,对Binder机制进行了解析。 概述 我们知道,在Android app中的众多activity,s...

linux进程间的通信(C): 使用信号量进行同步的共享内存机制

一、简介 共享内存为在多个进程之间共享和传递数据提供了一种有效的方式。 但它本身并未提供同步机制。 在实际编程中,可以使用   信号量,   传递消息(使用管道或IPC消息),   生成信...

Android进程间的通信 - IPC(机制)Binder的原理和源码阅读

1. 概述  当初决定分享内涵段子的这个项目我有些担心,担心很多东西心里虽然有了轮廓和细节。但是如果涉及到的东西比较多,那么就有可能没办法去讲太多的细节,况且某些哥们还不会C和C++,所以如果的确觉得...

nginx源码分析1———进程间的通信机制六(UNIX域协议)

相关介绍 Unix域协议并不是一个实际的协议族,而是在单机上客户端与服务器通信的一种方法。...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:进程间的通信机制
举报原因:
原因补充:

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