Chinaunix首页 | 论坛 | 博客
  • 博客访问: 78716
  • 博文数量: 22
  • 博客积分: 309
  • 博客等级: 二等列兵
  • 技术积分: 195
  • 用 户 组: 普通用户
  • 注册时间: 2012-10-23 13:50
文章分类

全部博文(22)

文章存档

2014年(1)

2012年(21)

我的朋友

分类: LINUX

2012-11-15 18:38:04

Linux给我们提供了丰富的内部进程通信机制,包括共享内存、内存映射文件、先入先出(FIFO)、接口(sockets)以及多种用于同步的标识。
    一般来说,内部进程通信(interprocess communication)也就是IPC,是指两个或两个以上进程以及两个或者两个以上线程之间进行通信联系。每个IPC机制都有不同的强项或者弱点, 不过没有一个IPC机制包含内建的同步方法。因此程序员不但需要自己在程序中实现同步,而且还需要为了利用IPC机制而自己开发通信协议。

共享内存
-----------------------------------------------------------
    使用共享内存和使用malloc()来分配内存区域很相似。使用共享内存的方法是:
    1 对一个进程/线程使用shmget()分配内存区域。
    2 使用shmat()放置一个或多个进程/线程在共享内存中,也可以用shmctl()来获取信息或者控制共享区域。
    3 使用shmdt()从共享区域中分离。
    4 使用shmctl()解除分配空间

    共享内存是Linux中最快速的IPC方法。它也是一个双向过程,共享区域内的任何进程都可以读写内存。这个机制的不利方面是其同步和协议都不受程序员控制,必须确保将句柄传递给了子进程和线程。

例程
-----------------------------------------------------------
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define PERM S_IRUSR|S_IWUSR

int main(int argc, char **argv)
{
    key_t shmid;
    char   *p_addr, *c_addr;
    pid_t pid;
    if(argc != 2) {
        fprintf(stderr, "Usage:%s/n/a", argv[0]);
        exit(1);
    }
    if( (shmid = shmget(IPC_PRIVATE, 1024, PERM)) == -1 )   { //(1)
        fprintf(stderr, "Create Share Memory Error:%s/n/a", strerror(errno));
        exit(1);
    }
    pid = fork();
    if(pid > 0) {
        p_addr = shmat(shmid, 0, 0);
        memset(p_addr, '/0', 1024);
        strncpy(p_addr, argv[1], 1024);
        wait(NULL);
        exit(0);
    }
    else if (pid == 0){
        sleep(1);
        c_addr = shmat(shmid, 0, 0);
        printf("Client get %s/n", c_addr);
        exit(0);
    }
}

(1)
IPC_PRIVATE            保证使用唯一ID
S_IRUSR | S_IWUSR      使当前用户可以读写这个区域

运行
-----------------------------------------------------------
$ ./a.out zengxiaolong
Client get zengxiaolong
$ ./a.out zengxiaolong



后记:
    进程通信(IPC)是网络程序的基础,在很多的网络程序当中会大量的使用进程通信的概念和知识.其实进程通信是一件非常复杂的事情,我在这里只是简单的介绍了一下.如果你想学习进程通信的详细知识,最好的办法是自己不断的写程序和看联机手册.
阅读(869) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~