当前位置: 首页 > news >正文

常宁做网站真正免费的网站建站平台有哪些

常宁做网站,真正免费的网站建站平台有哪些,南宁网站建设怎么样,山东省离线地图导航下载IPC 进程间通信方式:共享内存 原理 共享内存是最高效的进程间通信方式之一,因为它允许两个或多个进程直接访问同一块物理内存区域。这种机制避免了数据在用户空间和内核空间之间的频繁拷贝,从而显著提高了数据传输的效率。 在Linux系统中&…

IPC 进程间通信方式:共享内存

原理

共享内存是最高效的进程间通信方式之一,因为它允许两个或多个进程直接访问同一块物理内存区域。这种机制避免了数据在用户空间和内核空间之间的频繁拷贝,从而显著提高了数据传输的效率。

在Linux系统中,共享内存区域由内核管理,但可以由多个进程映射到它们各自的地址空间中。这样,进程就可以像访问本地内存一样直接读写这块共享内存区域。

操作流程
  1. 产生Key值
    使用ftok函数根据给定的路径名和项目ID生成一个唯一的键值(key),这个键值将用于后续的IPC对象操作。

  2. 申请共享内存
    使用shmget函数根据键值申请一块共享内存区域。如果申请成功,该函数会返回一个共享内存标识符(shmid)。

  3. 映射共享内存
    使用shmat函数将共享内存区域映射到进程的地址空间中,以便进程可以直接访问这块内存。

  4. 访问共享内存
    进程通过映射得到的地址直接读写共享内存中的数据。

  5. 解除映射
    使用shmdt函数解除共享内存与进程地址空间的映射关系。

  6. 销毁共享内存
    当不再需要共享内存时,可以使用shmctl函数并指定IPC_RMID命令来删除这块共享内存。

1. ftok - 生成key值
#include <sys/types.h> 
#include <sys/ipc.h> key_t ftok(const char *pathname, int proj_id);
  • 功能:将路径名pathname和工程IDproj_id转换为唯一的key值。
  • 参数
    • pathname:一个路径名。
    • proj_id:工程ID,通常是ASCII字符。
  • 返回值:成功时返回唯一的key值,失败时返回-1。
2. shmget - 申请共享内存
#include <sys/ipc.h> 
#include <sys/shm.h> int shmget(key_t key, size_t size, int shmflg);
  • 功能:使用唯一键值key向内核提出共享内存使用申请。
  • 参数
    • key:唯一键值。
    • size:要申请的共享内存大小。
    • shmflg:访问权限和创建标志(如IPC_CREAT、IPC_EXCL)。
  • 返回值:成功时返回共享内存ID,失败时返回-1。
3. shmat - 映射共享内存
#include <sys/types.h> 
#include <sys/shm.h> void *shmat(int shmid, const void *shmaddr, int shmflg);
  • 功能:将指定shmid对应的共享内存映射到本地内存。
  • 参数
    • shmid:共享内存ID。
    • shmaddr:本地地址,通常为NULL表示由系统自动分配。
    • shmflg:访问权限(如0表示读写,SHM_RDONLY表示只读)。
  • 返回值:成功时返回映射的地址,失败时返回(void*)-1。
4. shmdt - 撤销共享内存映射
#include <sys/types.h> 
#include <sys/shm.h> int shmdt(const void *shmaddr);

  • 功能:将本地内存与共享内存断开映射关系。
  • 参数shmaddr:要断开的映射地址。
  • 返回值:成功时返回0,失败时返回-1。
5. shmctl - 控制共享内存
#include <sys/ipc.h> 
#include <sys/shm.h> int shmctl(int shmid, int cmd, struct shmid_ds *buf);
  • 功能:修改共享内存属性或删除共享内存对象。
  • 参数
    • shmid:共享内存ID。
    • cmd:操作命令(如IPC_RMID表示删除对象)。
    • buf:指向shmid_ds结构的指针,用于传递信息或NULL(仅删除对象时)。
  • 返回值:成功时返回0,失败时返回-1。
6.示例

假设我们有两个进程a.outb.out,它们需要通过共享内存交换一个pid_t类型的进程ID。

a.out(写进程)

#include <stdio.h> 
#include <stdlib.h> 
#include <string.h> 
#include <sys/ipc.h> 
#include <sys/shm.h> 
#include <sys/types.h> 
#include <unistd.h> int main() 
{ key_t key = ftok("/tmp", 'A'); int shmid = shmget(key, sizeof(pid_t), IPC_CREAT | 0666); if (shmid == -1) { perror("shmget"); exit(EXIT_FAILURE); } void *shmaddr = shmat(shmid, NULL, 0); if (shmaddr == (void *)-1) { perror("shmat"); exit(EXIT_FAILURE); } pid_t *pid_ptr = shmaddr; *pid_ptr = getpid(); // 将当前进程的PID写入共享内存 shmdt(shmaddr); shmctl(shmid, IPC_RMID, NULL); return 0; 
}


b.out(读进程)

#include <stdio.h> 
#include <stdlib.h> 
#include <sys/ipc.h> 
#include <sys/shm.h> 
#include <sys/types.h> 
#include <unistd.h> int main() 
{ key_t key = ftok("/tmp", 'A'); int shmid = shmget(key, sizeof(pid_t), 0666); if (shmid == -1) { perror("shmget"); exit(EXIT_FAILURE); } void *shmaddr = shmat(shmid, NULL, 0); if (shmaddr == (void *)-1) { perror("shmat"); exit(EXIT_FAILURE); } pid_t *pid_ptr = shmaddr; printf("Received PID: %d\n", *pid_ptr); shmdt(shmaddr); return 0; 
}
7.总结
  1. 共享内存数据的存储方式是拷贝还是剪切?
    答:在共享内存的情况下,数据是直接访问的,不涉及拷贝或剪切操作。进程直接通过映射的地址访问物理内存区域。

  2. 共享内存的数据如果多次不同进程读写会怎么样?
    答:如果多个进程读写同一块共享内存区域,并且没有适当的同步机制(如信号量),那么可能会出现数据竞争和覆盖的情况

http://www.hkea.cn/news/999453/

相关文章:

  • 学校营销型网站建设网站优化教程
  • 解释自己做的网站搜一搜站长工具
  • wordpress最新版获取标签seo简单优化操作步骤
  • 电子工程师网站舆情监测软件免费版
  • 建设一个网站需要用到几个语言seo搜索引擎优化试题
  • 云南省住房与城乡建设厅网站关键词排名零芯互联排名
  • 山东坤泰建设集团网站手机百度搜索app
  • wordpress php推送示例seozou是什么意思
  • 做网站多久天津seo网站管理
  • 建设局查询网站网络上市场推广
  • 怎么做装修网站b2b多平台一键发布
  • ASP做网站源代码大专网络营销专业好不好
  • 网络公司网站 优帮云做网站排名服务热线
  • 制作网页设计软件列表案例谷歌seo 优化
  • wordpress网站备案上海搜索推广
  • 网站建设套餐有哪些安卓在线视频嗅探app
  • 做电影网站要买什么重庆seo网站哪家好
  • 广州北京网站建设公司网站外部优化的4大重点
  • 网站建设书优化大师是干什么的
  • 优秀的网站建设公司百度指数人群画像
  • wordpress企业中文模板太原seo哪家好
  • 广东网广东网站建设网站推广方案模板
  • 网站运营知识快手seo
  • 咖啡公司网站建设策划书微信营销方式
  • 柳江区城乡住房建设局网站上海seo优化服务公司
  • 西城企业网站建设企业网站怎么优化
  • 初学者做动态网站项目例子游戏特效培训机构排名
  • 汽车类网站搭建直链平台
  • 做网站遇到的困难总结网络营销软件代理
  • 做网站登录论坛外链代发