设为首页 友情链接
在线留言 发表文章
加入收藏 广告联系

刺猬首页

| 专案技术 | 网络技术 | 图形图象 | 网络编程 | 网页设计 | 操作系统 | 服务器 | 技术白皮书 | 在线实验室 | 刺猬论坛 |
小说专版  | 数据库 | 设计赏析 | 存储频道 | 网络安全 | 私服架设 |  Solaris | 网站评估 | PC维护技巧 | 下载中心 | 博 客 |
专   题: | Linux | java | cisco | 防病毒 | 刀片 | SOA | iscsi | ASP.NET | SQL | Oracle |
您现在的位置: 刺猬宫 >> Linux专题 >> Linux 软件开发 >> 教程正文 用户登录 新用户注册
专 题 栏 目
最 新 热 门
最 新 推 荐
相 关 文 章
Linux系统下Apache服务器…
巧用Tmpfs加速你的Linux…
Linux系统平台上文档服务…
Linux+Apache+Mysql+PHP…
Linux环境下邮件服务器软…
Linux系统的网络服务器配…
搭建Linux下的Squid代理…
Linux服务器网卡驱动安装…
Linux精华 Tomcat配置技…
Linux上安装Apache+Php+…
  Linux中共享内存及内存映射技术研究         
Linux中共享内存及内存映射技术研究
 

Linux给我们提供了丰富的内部进程通信机制,包括共享内存、内存映射文件、先入先出(FIFO)、接口(sockets)以及多种用于同步的标识。在本文中,我们主要讨论一下共享内存和内存映射文件技术。

一般来说,内部进程通信(interprocess communication)也就是IPC,是指两个或两个以上进程以及两个或者两个以上线程之间进行通信联系。每个IPC机制都有不同的强项或者弱点,不过没有一个IPC机制包含内建的同步方法。因此程序员不但需要自己在程序中实现同步,而且还需要为了利用IPC机制而自己开发通信协议。

共享内存

使用共享内存和使用malloc来分配内存区域很相似。使用共享内存的方法是:

1.对一个进程/线程使用shmget分配内存区域。

2.使用shmat放置一个或多个进程/线程在共享内存中,你也可以用shmctl来获取信息或者控制共享区域。

3.使用shmdt从共享区域中分离。

4.使用shmctl解除分配空间

下面是个例子:

  

  //建立共享内存区域

  intshared_id;

  char *region;

  const intshm_size = 1024;

  

  shared_id = shmget(IPC_PRIVATE,//保证使用唯一ID

            shm_size,

            IPC_CREAT | IPC_EXCL |//创建一个新的内存区域

            S_IRUSR | S_IWUSR);//使当前用户可以读写这个区域

  

  //交叉进程或生成进程.

  

  //将新建的内存区域放入进程/线程

  region = (char*) shmat(segment_id, 0, 0);

  

  //其他程序代码

  ...

  

  //将各个进程/线程分离出来

  shmdt(region);

  

  //破坏掉共享内存区域

  shmctl(shared_id, IPC_RMID, 0);
  

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

内存映射文件

内存映射文件不仅仅用于IPC,在其他进程中它也有很大作用。如果你需要将一个分配的缓冲区初始化为零,只要记住/dev/zero 。你也可以通过将文件映射到内存中以提高其性能。它使你可以像读写字符串一样读写文件。下面是个例子:

  

  const char filename[] = "testfile";

  intfd;

  char *mapped_mem;

  const intflength = 1024;

  fd = open(filename, O_RDWR | O_CREAT, S_IRUSR | S_IWUSR);

  lseek(fd, flength + 1, SEEK_SET);

  write(fd, "\0", 1);

  lseek(fd, 0, SEEK_SET);

  

  mapped_mem = mmap(0,

           flength,

           PROT_WRITE, //允许写入

           MAP_SHARED,//写入内容被立即写入到文件

           fd,

           0);

  

  close(fd);

  

  //使用映射区域.

  ...

  

  munmap(file_memory, flength);
  

利用内存映射来处理IPC的好处是在整个过程中你不需要处理句柄:只要打开文件并把它映射在合适的位置就行了。你可以在两个不相关的进程间使用内存映射文件。

使用内存映射的缺点是速度不如共享内存快。如果凑巧文件很大,所需要的虚拟内存就会很大,这样会造成整体性能下降。

Linux联盟收集整理

频道声明:本频道的文章除部分特别声明禁止转载的专稿外,可以自由转载.但请务必注明出出处和原始作者 文章版权归本频道与文章作者所有.对于被频道转载文章的个人和网站,我们表示深深的谢意。

原始作者:佚名 录入时间:2007-5-12 03:58:15
信息来源:不详 投稿信箱:itqoo@126.com
教程录入:itqoo    责任编辑:itqoo 
  • 上一个教程:

  • 下一个教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    - 关于我们 - 合作伙伴 - 友情链接 - 广告刊登 - 投稿热线 - 在线留言版权声明联系方式 -
    IT公社版权所有 粤ICP备05127012号
    Copyrigh@2005-2006 itqoo.com.Inc All Rights Reserved  推荐分辨率 1024*768
    联系站长:E-Mail:itqoo@126.com     MSN:urchincc@hotmail.com    QQ:点击这里给我发消息
    特别感谢:亿太网络提供空间支持