如果想要获取的共享内存,是刚刚新创建出来的共享内存,则返回 *** 作句柄总结:使用shmget这个函数的时候一定要自己刚刚创建出来的共享内存返回值:返回的是共享内存的 *** 作句柄共享内存命令ipcs:查看共享内存ipcrm -m [shmid]:删除共享内存共享内存的声明周期是跟随着 *** 作系统内核的将共享内存附加到进程void shmat(int shmid, const void shmaddr, int shmflg)shmid:共享内存的 *** 作句柄shmaddr:附加到共享内存的什么虚拟地址,允许传递NULL值,让 *** 作系统帮我们选择附加到共享内存区当中的那个地址,这个地址通过该函数的返回值返回给我们shmflg:① SHM_RDONLY:规定当前进程只能对共享内存进行读 *** 作② 0:可读可写返回值:返回共享内存附加到共享区的地址结论:进程在读取共享内存的时候,是访问,并不是拿走!将共享内存和进程分离int shmdt(const void *shmaddr)shmaddr:shmat的返回值 *** 作共享内存int shmctl(int shmid, int cmd, struct shmid_ds *buf)shmid:共享内存 *** 作句柄cmd:告诉shmctl函数需要做什么 *** 作① IPC_STAT:获取当前共享内存的属性信息,放在buf中,buf是出参② IPC_SET:设置共享内存的属性信息,是用buf来进行设置的,buf是入参③ IPC_RMID:删除共享内存,buf可以直接传递NULLbuf:共享内存的结构体4.共享内存的标识符和共享内存的 *** 作句柄的区别是什么?标识符:是用来标识共享内存的,相当于共享内存的身份z,意味着不同的进程可以通过标识符找到这个共享内存 *** 作句柄:进程可以通过 *** 作句柄来对共享内存进行 *** 作(,附加,分离,删除)5.删除共享内存当使用shmctl或者使用ipcrm,删除共享内存之后,共享内存就实际被释放掉了当共享内存被释放掉之后,共享内存的标识符会被设置为0x00000000,表示其他进程不能通过之前的标识符找到该共享内存,并且共享内存的状态会被设置为dest(destroy)当共享内存被释放掉之后,但是还是有进程在附加着共享内存,当前描述共享内存的结构体并没有被释放,直到当前共享内存的附加进程数量为0的时候才会释放掉。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)