C语言中,指向动态内存的指针被free释放后还能不能使用,网上找了好久没找到满意的答案。

代码运行之后是能出结果的,但是网上的课说不可以,课里面也没有演示,希望有师傅解读一下

代码如下:


int main() {
    char* str = malloc(100);
    strcpy(str, "hello");
    free(str);
    if (str != NULL) {
        strcpy(str, "world");
        printf(str);
    }
    return 0;
}

结果:

img

你这么理解。。。。
你malloc 出来的是什么?
是个内存对吧?
那么内存你怎么指挥,或者说操作呢?
通过地址。。。对吧?
加入这个malloc 的地址为 0x1234,然后你就可以通过这个0x1234,开始各种操作。。。。
当你free 之后,那么这个内存,就不再属于你的进程了,在系统中(例如手机平台) 其他的进程这个时候也在malloc,恰好也申请了 0x1234
而此时这个进程在做绝密的操作,这个0x1234 中数据很重要,结果你来个strcpy。。。
ok。。。你知道该发生什么了。。。

能运行是运气,这块空间在你使用的时候是空闲的,一旦被分配给其它进程,你这代码就会崩溃的

img

这里涉及的是内存分配相关的知识点,malloc管理内存分配,返回给你的是一块内存的首地址让你去用,free后,这块内存在管理上已经释放了,虽然你后面用看起来没错,但是实际上是非法使用了。
比如,如果我后面再申请内存,内存管理中因为这块内存已经释放了就可以被用,这样使用你就对后面str1有影响,所谓的内存泄露相关了