4

这是另一个问题的类似物,无论如何我正在寻找一种特定于平台的方法来做到这一点,如果它存在于 iOS 上。

为 Apple 平台开发意味着基于非 Apple 的工具集通常不太适用。所以我希望找到平台原生的方式来做到这一点。因为简单的谷歌搜索给了我this( heapcommand),所以我确信还有一个 API 函数。

我正在寻找这个只是为了调试构建断言来检测删除堆栈分配对象的情况。所以知道地址指向哪里就足够了——堆栈或堆。因此,性能、版本兼容性、内部 API 或任何质量问题都无关紧要。(也许在模拟器上测试也可以是一种选择)但是我认为如果堆栈与堆完全分离,这并不是那么繁重的操作。

我标记了 C++,但任何其他语言的 API 如果适用于 C++ 也可以。

4

1 回答 1

1

如果您glibc在 iOS 上使用 GNU GCC 编译器,那么我相信您可以使用mprobe()- 如果它失败,则内存块已损坏或堆栈内存块。

http://www.gnu.org/software/libc/manual/html_node/Heap-Consistency-Checking.html

使用 OS 可移植堆检测更新帖子:

new()否则,您可以通过覆盖&来创建自己的堆内存管理器delete(),记录所有堆内存分配/释放,然后添加自己的堆检测功能;示例如下:

// Untested pseudo code follows:
//
#include <mutex>
#include <map>
#include <iostream>

std::mutex g_i_mutex;
std::map<size_t, void*> heapList;

void main()
{
   char var1[] = "Hello";
   char *var2 = new char[5];

   if (IsHeapBlock(&var1))
      std::cout "var1 is allocated on the heap";
   else
      std::cout "var1 is allocated on the stack";

   if (IsHeapBlock(var2))
      std::cout "var2 is allocated on the heap";
   else
      std::cout "var2 is allocated on the stack";

   delete [] var2;
}

// Register heap block and call then malloc(size)
void *operator new(size_t size) 
{
   std::lock_guard<std::mutex> lock(g_i_mutex);
   void *blk = malloc(size);
   heapList.Add((size_t)blk, blk);
   return blk;
}

// Free memory block
void operator delete(void *p)
{
   std::lock_guard<std::mutex> lock(g_i_mutex);
   heapList.erase((size_t)p);
   free(p);
}

// Returns True if p points to the start of a heap memory block or False if p
// is a Stack memory block or non-allocated memory
bool IsHeapBlock(void *p)
{
   std::lock_guard<std::mutex> lock(g_i_mutex);
   return heapList.find((size_t)p) != heapList.end();
}

void *operator new[] (size_t size)
{
   return operator new(size);
}

void operator delete[] (void * p)
{
   operator delete(p);
}
于 2013-07-24T02:08:41.833 回答