1

我正在为正在优化的(Win7)C++ 例程编写回归测试,该例程以前释放并重新分配了许多巨大的缓冲区:内存流失。我想证明,在测试期间,程序不会分配任何大内存区域(比如 16M 或更大),而是有效地重新使用在初始化时分配的内存。归结为,如果调用 VirtualAlloc 以获取一些大区域(例如 16M),则测试应该失败。

有没有一种优雅的方法来计算对 Windows VirtualAlloc 的调用的统计信息?这将成为永久自动回归测试套件的一部分,因此使用外部工具或修改下游代码是不可行的。

检查提交的总内存不太合适,因为我想断言例程不再搅动(释放和重新分配缓冲区。)

4

2 回答 2

1

依赖注入。

不是让被测代码调用本机内存分配器,而是传递一个指向代码可以使用的分配器对象的指针。对于生产代码,此分配器对象仅调用本机内存分配函数。对于测试,您传入一个检查和/或记录大小的分配器。

于 2015-07-29T22:53:02.173 回答
1

挂钩

Detours可以挂钩任意方法调用,但是

  • 它仅免费用于非商业用途
  • 对于单元测试来说,这可能是矫枉过正

RohitabEasyhook似乎提供了类似的东西。

备择方案

如果您的进程是 32 位的,您可以提前分配 4080 MB(或多或少),并且对 VirtualAlloc 的更多调用将失败。这不包括您多次分配/取消分配 16 MB 的情况。如果您保留这些 4080 MB,这甚至会很快,因为不需要实际内存。

于 2015-07-29T21:25:16.193 回答