开发者

shared memory (ipc)in linux

开发者 https://www.devze.com 2023-02-16 00:23 出处:网络
Shared memory means one process will create a mem开发者_开发技巧ory portion oher process can acess.

Shared memory means one process will create a mem开发者_开发技巧ory portion oher process can acess.

My question is: how will the other process know the created shared memory shmid (i.e shmid=shmget(key-t ,size , permission);)?


To simplify: The process that creates the shared memory defines the name and permissions (process of the logged in user).

Basically you create a file:

file_descriptor = shm_open("/some.shared.memory", 
                   (O_CREAT | O_RDWR),
                   (S_IREAD | S_IWRITE))  

Or if it exists you can open it:

file_descriptor = shm_open("/some.shared.memory",
                   (O_CREAT | O_EXCL | O_RDWR),
                   (S_IREAD | S_IWRITE))

Thus, the name "/some.shared.memory" is your way to find the shared segment. (Note the flags)

  • Have a look here http://www.kernel.org/doc/man-pages/online/pages/man7/shm_overview.7.html
  • Do a Google search on "shm_open example" and you'll find lots of examples.
  • The process that creates the file will determine the permissions (owner+group) See the chown command and fchmod functions which you can call to set the permissions. Also have a look at umask.


They need to use the same way to derive the key_t; usually you use the ftok function where both sides use the same file name and id value, so they end up with the same key.

0

精彩评论

暂无评论...
验证码 换一张
取 消