管道的自我实现,如何知道有多少进程有我的管道的文件描述符?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了管道的自我实现,如何知道有多少进程有我的管道的文件描述符?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1402字,纯文字阅读大概需要3分钟。
内容图文
![管道的自我实现,如何知道有多少进程有我的管道的文件描述符?](/upload/InfoBanner/zyjiaocheng/970/68c290930b444df9af8d070857599bc8.jpg)
我需要自己实现一个管道,它将具有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()之前做出的任何分配,因为它们不仅具有分配的内存的副本,而且还有内存分配控制结构的副本.但是,它们实际上每个都有不同的分配,包含相同的数据(通过写时复制实现).
内容总结
以上是互联网集市为您收集整理的管道的自我实现,如何知道有多少进程有我的管道的文件描述符?全部内容,希望文章能够帮你解决管道的自我实现,如何知道有多少进程有我的管道的文件描述符?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。