如何在iOS上检查指针是否指向堆或堆栈内存

How to check a pointer is pointing heap or stack memory on iOS?

本文关键字:内存 堆栈 是否 指针 iOS 检查      更新时间:2023-10-16

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

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

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

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

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

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

更新了操作系统可移植堆检测的帖子:

否则,您可以通过重写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);
}