进程间通信:共享内存(代码实现)

共享内存:1.共享内存就是允许两个不相关的进程访问同一个逻辑内存;

                    2.共享内存是在两个正在运行的进程之间共享和传递数据的一种最有效的方式;

                    3.不同进程之间共享的内存通常安排为同一段物理内存;

                    4.共享内存不提供任何互斥和同步机制,一般用信号量对临界资源进行保护;

                    5.接口简单

1.shmget:该函数用来创建共享内存

进程间通信:共享内存(代码实现)_第1张图片

_key:程序需要提供一个参数key(非0整数),它有效地为共享内存段命名,shmget函数成功时返回一个与key相关的共享内存标识符(非负整数),用于后续的共享内存函

             数。调用失败返回-1。

_size:size以字节为单位指定需要共享的内存容量。

shmflg:是权限标志,它的作用与open函数的mode参数一样,如果要想在key标识的共享内存不存在时,创建它的话,可以与IPC_CREAT做或操作。共享内存的权限标志与

                文件的读写权限一样,举例来说,0644,它表示允许一个进程创建的共享内存被内存创建者所拥有的进程向共享内存读取和写入数据,同时其他用户创建的进程只能读

                取共享内存。

2.shmat:第一次创建完共享内存时,它还不能被任何进程访问,shmat函数的作用就是用来启动对该共享内存的访问,并把共享内存连接到当前进程的地址空间。


shm_id:由shmget函数返回的共享内存标识。

shm_addr:指定共享内存连接到当前进程中的地址位置,通常为空,表示让系统来选择共享内存的地址。

shm_flg:是一组标志位,通常为0。

3.shmdt:该函数用于将共享内存从当前进程中分离。注意,将共享内存分离并不是删除它,只是使该共享内存对当前进程不再可用。

进程间通信:共享内存(代码实现)_第2张图片

shmaddr:shmat函数返回的地址指针,调用成功时返回0,失败时返回-1。

4.shmctl:用来控制共享内存

进程间通信:共享内存(代码实现)_第3张图片

shm_id:shmget函数返回的共享内存标识符。

command:要采取的操作,它可以取下面的三个值 :

    IPC_STAT:把shmid_ds结构中的数据设置为共享内存的当前关联值,即用共享内存的当前关联值覆盖shmid_ds的值。

    IPC_SET:如果进程有足够的权限,就把共享内存的当前关联值设置为shmid_ds结构中给出的值。

    IPC_RMID:删除共享内存段。

buf:一个结构指针,它指向共享内存模式和访问权限的结构。

代码:

com.h:

进程间通信:共享内存(代码实现)_第4张图片

com.c:

进程间通信:共享内存(代码实现)_第5张图片

进程间通信:共享内存(代码实现)_第6张图片

server.c:

进程间通信:共享内存(代码实现)_第7张图片

client.h:

进程间通信:共享内存(代码实现)_第8张图片


结果:

进程间通信:共享内存(代码实现)_第9张图片

进程间通信:共享内存(代码实现)_第10张图片

你可能感兴趣的:(Linux,操作系统,C/C++开发学习)