,让这部分空间能继续用于之后的动态分配.当ptr为空指针时,不执行任何操作.除此之外,当实际参数与之前通过malloc(),calloc(),realloc()返回的指针不一致时,或者ptr指向的空间已经通过调用...可以看到,编译器直接报错"检测到堆损坏".像这种报错不论是说栈区损坏,还是堆区损坏,意思就是在栈上或堆上出现了越界访问的情况....因此,在使用动态内存开辟空间时,我们要格外小心不要出现越界访问的问题.
3.对非动态开辟内存使用free释放
因为p是由编译器分配到栈区的,不属于堆区,因此不能使用free释放.
void test...而图中的报错"已执行断点指令"则是因为代码执行过程中出现了未定义的非法行为.
4.使用free释放一块动态开辟内存的一部分
如下代码:
void test()
{
int *p = (int...*)malloc(100);
p++;
free(p); //p不再指向动态内存的起始位置
}
在vs2022中测试一下:
可以看到,该错误导致了程序异常终止.
5.对同一块动态内存多次释放