C++ freeing static variables referring heap resource

本文探讨了C++中静态变量的生命周期及释放方式。一种方法是在主函数返回后销毁静态std::auto_ptr。另一种方法是注册一个atexit函数,在程序退出时删除静态指针。这两种方法都能确保静态变量被正确清理。
It will have static lifetime and be destroyed after main returns:
static std::auto_ptr<T> thePointer;



Another option is to register your own atexit function:

// static
void YourClass::freePointer(void)
{
    delete getPointer();
}

// static
T* YourClass::getPointer(void)
{
    if (!thePointer)
    {
        thePointer = new T;
        atexit(freePointer);
    }

    return thePointer;
}

Which will have the same effect.



http://stackoverflow.com/questions/2429408/c-freeing-static-variables

### 判断地址是否有效的实现方式 在C++14中,标准库并未提供直接的方法来验证内存地址的有效性。然而,在实际开发过程中可以通过一些间接手段来进行判断。以下是几种常见的方法: #### 方法一:通过指针解引用捕获异常 如果尝试访问一个无效的内存地址,则可能会引发未定义行为或者程序崩溃。因此可以利用`try-catch`机制捕捉可能发生的错误。 ```cpp #include <iostream> #include <stdexcept> bool isValidAddress(void* ptr) { try { char test = *static_cast<char*>(ptr); return true; } catch (...) { return false; } } int main() { int value = 42; void* validPtr = &value; void* invalidPtr = nullptr; std::cout << "Valid pointer: " << (isValidAddress(validPtr) ? "true" : "false") << "\n"; std::cout << "Invalid pointer: " << (isValidAddress(invalidPtr) ? "true" : "false") << "\n"; return 0; } ``` 这种方法存在局限性,因为某些平台上的非法操作不会抛出异常而是直接终止进程[^1]。 #### 方法二:使用操作系统特定API 不同操作系统提供了各自的函数用于检测指定区域内的内存状态。例如Windows下的VirtualQuery以及Linux中的mincore等工具可以帮助我们了解目标位置的状态信息。 对于UNIX-like系统而言,下面展示了一个简单的例子如何调用`mincore()`来检查给定范围是否存在物理页映射: ```c++ #include <sys/mman.h> #include <unistd.h> #include <cstring> #include <cstdio> #include <cstdlib> // Check whether a specific range of addresses has been allocated. bool isAllocated(const void* addr, size_t length){ unsigned char vec[length / getpagesize()]; if(mincore((void*)addr,length,&vec)==-1)return false; for(auto i=std::begin(vec);i!=std::end(vec);++i) if(*i&1)return true;// If any bit set means corresponding page present in RAM. return false ; } int main(){ const auto p=(char*)malloc(8*sizeof(char)); printf("%d\n",isAllocated(p,8));// Should output '1' free(p); printf("%d\n",isAllocated(p,8));// Might print either '0' or crash depending upon system behavior after freeing memory block. exit(EXIT_SUCCESS); } ``` 需要注意的是这类解决方案通常依赖于底层硬件架构特性并且跨平台兼容性较差[^3]。 #### 总结 尽管C++本身缺乏内置支持去精确判定任意指针对应资源当前可用情况,但借助高级技巧还是能够达成目的。不过这些技术往往伴随着额外开销或是牺牲了一部分可移植性质等问题需要权衡考虑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值