fork() 并释放所有分配的内存
fork() and free all allocated memory
我正在编写一个服务(即后台进程),并希望通过共享库启动它。也就是说,想要使用该服务的人将链接到共享库,调用它的start()方法,该方法将分叉并返回。然后,分叉将运行该服务。
这种方法的问题在于,服务进程现在可能有很多实际上不需要的旧分配内存。有没有办法摆脱它并让分叉进程分配自己的东西?我当然知道exec(),但问题是
- 我需要由于不同的操作系统文件夹布局,它可能不在我期望的位置
- 我必须将所有潜在参数转换为字符串才能将其作为程序参数传递给 exec()。
所以基本上,我正在寻找一种方法来调用任意函数func(),其中包含一些应该在新进程中运行的参数,并且未传递到该函数中的所有内容都不应该在新进程中。有没有办法实现这一点或类似的东西?
这是一个有趣的问题,我很遗憾没有一个好的答案。我怀疑任何像 sbrk+close+munmap 这样的清理策略都能可靠地允许任何基于 libc 的代码继续运行,所以我会尝试让执行更好:
对于任何类型的基于 exec 的解决方案,您应该能够将数据深拷贝到 shm 中以传递非字符串。这应该可以解决您的第二个问题。
以下是针对您的第一个问题的一些疯狂建议:
-
不要:只要求可执行文件位于 PATH 或编译时目录中。
这是透明的,并遵循 UNIX 理念。错误消息
Can't find myhelper in PATH
不会减慢任何人的速度。大多数依赖于帮助程序可执行文件的工具都会执行此操作,这很好。 -
使您的库可执行,并将其用作执行目标。你可以尝试通过某种内省来找到它的名字,也许是
/proc/self/maps
或任何glibc提供的东西。 -
如上所述,但 exec
python
或者你可以合理确定存在的东西,并使用外部指针接口在你的库上运行一个函数。
作为 构建过程的一部分,编译一个微小的可执行文件,并将其作为二进制数据包含在库中。将其写入
/tmp
并执行。
我更喜欢#1的简单性和透明度,即使这是最无聊的解决方案。
- 在c++中为我自己的基于指针的数组分配内存的正确方法
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 如果 const 不分配内存,为什么我可以获取 const 的地址?
- 在函数中分配内存时出现问题
- 如何为 std::vector 分配内存,然后稍后为某些元素调用构造函数?
- constexpr new 如何分配内存?
- 在构造函数中分配内存失败是如何冒泡的
- LLVM 传递以在特定地址分配内存
- CudaMalloc 在分配内存时失败
- 为什么它在不分配内存的情况下工作正常
- 为什么在正确解除分配内存时出现内存泄漏?
- 如何通过 malloc 为队列数组分配内存?
- vector是否为std::移动的对象连续分配内存
- 删除类成员的动态分配内存的最佳方法是什么
- 唯一指针是否在堆或堆栈上分配内存?
- 如果不分配内存,我如何能够为变量创建和分配值?
- std::initializer_list 堆是否分配内存?
- 如何按顺序或在指定的地址分配内存?
- 是否可以使用 malloc 为类对象分配内存?
- 迭代器是否分配内存(如指针)?