管道的自我实现,如何知道有多少进程有我的管道的文件描述符?
作者:互联网
我需要自己实现一个管道,它将具有pipe()
,read()
,write()
和close()
的常规管道功能.管道用作父进程和子进程之间的通信通道,这意味着程序将使用fork()
,可能不止一次.
我的想法是在pipe()函数中使用malloc来实现它,它将在close()函数中释放,但是当fork命令发生时,我将最终有多个进程将文件描述符保存到我的管道,并且这是我无法弄清楚的部分:
我怎么知道fork()被调用了多少次以及有多少进程可以访问我的管道?
如何阻止关闭其管道一端访问权限的进程为其他所有进程关闭?如何确保关闭管道的最后一个进程将释放其内存?
Update
实际上它意味着使用文件描述符,并且进程不管理这个内存,它们只能访问它,我需要一种方法来防止进程在关闭之前关闭它的一端.所有其他人,并确保一旦所有结束关闭,内存将被释放.
解决方法:
我想你想要做的是实现像pipe(),但实际上没有使用pipe()(甚至FD),而是使用内存.
当程序执行fork()时,它的FD可供子级和父级使用.因此,使用pipe(),子进程可以写入,父进程可以读取(反之亦然).但是,子进程会继承父进程内存的写时复制副本.因此,父母不会看到孩子所做的任何写作,反之亦然.另一方面,如果使用线程,则内存映射是真正共享的.
您要做的是IPC(进程间通信)的一种形式.如果您不想使用内存,则需要特殊类型的内存.一种方法是使用shmget,shmctl等 – 有例子here.
但是,您必须自己管理内存分配,而不是使用malloc()和free(). malloc()和free()在堆上运行,不会使用共享内存段.
为了完整性,你的问题的答案在技术上是父和所有孩子必须每个释放父在fork()之前做出的任何分配,因为它们不仅具有分配的内存的副本,而且还有内存分配控制结构的副本.但是,它们实际上每个都有不同的分配,包含相同的数据(通过写时复制实现).
标签:c-3,linux,pipe,fork,file-descriptor 来源: https://codeday.me/bug/20190528/1171998.html