加粗样式# system v共享内存
进程通信的前提条件是:让不同进程看见同一份资源。
共享内存:其实就是进程获取共享区里面的地址,该地址为物理内存中某块我所需要资源的地址(该内存是创建的共享内存处在共享区里),地址通过页表映射到共享区上。
获取共享内存函数shmget
参数key是一个共享内存的唯一值。
size代表创建共享内存的大小(建议设置成为页(4KB)的整数倍)
shmflg
IPC_CREAT:创建共享内存,如果已经存在就获取它,不存在就创建它。
IPC_EXCL:不单独使用必须和IPC_CREAT配合。如果不存在指定的共享内存就创建它。存在就出错返回。
当IPC_CREAT与IPC_EXCL一起使用可以保证,如果shmget函数调用成功一定是一个全新的共享内存(share memory)
共享内存存在内核中 – 内核会给我们维护共享内存的结构。
共享内存的(生命周期是随内核的)。(如果不显示的删除只能通过kernel(os)重启来解决).
如何查看共享内存
ipcs -q ipcs -s
ipcs -m//查看共享内存列表
删除共享内存
ipcrm -m 4//(ipcrm代表共享资源 -m表示删除 4为shmmid)
共享内存实际上是映射到了我们进程地址空间的用户空间位置在堆炸直接。对每个进程而言挂接到自己的上下文中的共享内存,属于自己的空间。类似于堆空间或者栈空间,可以被用户直接使用。
共享内存,因为它自身的特性,没有任何访问控制!共享内存被双方直接看到,属于双方的用户空间,可以直接通信但是不安全。
我们也可以通过获取用户的输入内容在传入共享内存中。
在一个进程中输入通过另外个进程就可以看到缓冲区的内容。
对于多个进程,访问临界资源的代码 – 临界区
进程代码中,有大量代码但只有一部分代码会访问临界资源。
信号量需要掌握的几种信号量
多元信号量:表示数字可以一直往后延伸直至你需要的数字为止。
而二元信号量只有0与1。
多执行流导致更改。
信号量是一个计数器,这个计算器对应的操作是原子的。所谓的原子指的是一件事情要么不做,要么做了就要做完