void* 指针释放

C++中,void*指针在释放时需要特别注意。错误的释放方式可能导致内存泄漏或析构函数未被调用。删除void*指针时,系统按基本类型大小释放,而非实际类型。若void*指向数组,需使用delete[],若指向类对象,析构函数不会自动调用。正确的做法是先将void*转换回原始类型,再进行delete或delete[]操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在C、C++ 中,void * 指针可以转换为任意类型的指针类型,在删除void*指针时编译器往往会发出如下警告

main.cpp:28:9: warning: deleting ‘void*’ is undefined [-Wdelete-incomplete]

翻译:警告:删除“void *”指针可能引发未知情况(默认打开警告)

并且,根据删除的void*的实际类型的不同,会导致不同的内存不能有效释放的问题

释放void* ,系统会以释放普通指针(char, short, int, long, long long)的方式来释放void*,并不是实际类型大小的空间;

如果void *指向一个数组指针,那么由于释放指针时用了delete p

### C语言 `void **` 的使用方法 #### 定义与特性 `void **` 是一种双重指针,它指向一个 `void *` 类型的变量。由于 `void *` 是一种通用指针类型,能够指向任意数据类型,因此 `void **` 可以用于管理多个不同类型的指针对象。然而,需要注意的是,在操作 `void **` 时,仍然需要遵循严格的类型转换规则[^1]。 #### 主要用途 1. 动态内存分配后的指针数组管理。 2. 泛型编程场景下,允许函数接收并修改多种类型的指针集合。 3. 实现跨平台或跨模块的数据交换接口。 #### 特殊注意事项 - 和单层 `void *` 不同,双层间接寻址意味着更复杂的上下文依赖关系。如果未正确初始化底层指针,则可能导致不可预测的行为甚至程序崩溃。 - 对于某些严格模式下的编译器来说,直接赋值可能引发警告或错误提示;此时需显式执行强制类型转换 (cast)[^3]。 下面给出一段简单的代码示例来展示其基本功能: ```c #include <stdio.h> #include <stdlib.h> // 函数声明:接受 void** 参数调整原始 int*void modifyPointer(void **pptr); int main() { int value = 42; int *pValue = &value; printf("Before modification: %d\n", *pValue); // 调用函数前先传入二级指针形式 modifyPointer((void **)&pValue); printf("After modification: %d\n", *pValue); free(pValue); // 记得释放新分配的空间 return 0; } void modifyPointer(void **pptr){ *(int **)pptr = malloc(sizeof(int)); // 将 pptr 所指向的位置重新设置为新的整数地址 **(int**)pptr = 99; // 修改该位置的内容为另一个数值 } ``` 上述例子展示了通过 `modifyPointer()` 方法改变外部定义好的指针所指向的实际内容的过程。这里特别强调了 `(void**)&pValue` 这样的写法是为了兼容那些不允许隐含提升语义的语言环境设定[^2]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值