代码运行之后是能出结果的,但是网上的课说不可以,课里面也没有演示,希望有师傅解读一下
代码如下:
int main() {
char* str = malloc(100);
strcpy(str, "hello");
free(str);
if (str != NULL) {
strcpy(str, "world");
printf(str);
}
return 0;
}
结果:
你这么理解。。。。
你malloc 出来的是什么?
是个内存对吧?
那么内存你怎么指挥,或者说操作呢?
通过地址。。。对吧?
加入这个malloc 的地址为 0x1234,然后你就可以通过这个0x1234,开始各种操作。。。。
当你free 之后,那么这个内存,就不再属于你的进程了,在系统中(例如手机平台) 其他的进程这个时候也在malloc,恰好也申请了 0x1234
而此时这个进程在做绝密的操作,这个0x1234 中数据很重要,结果你来个strcpy。。。
ok。。。你知道该发生什么了。。。
能运行是运气,这块空间在你使用的时候是空闲的,一旦被分配给其它进程,你这代码就会崩溃的
这里涉及的是内存分配相关的知识点,malloc管理内存分配,返回给你的是一块内存的首地址让你去用,free后,这块内存在管理上已经释放了,虽然你后面用看起来没错,但是实际上是非法使用了。
比如,如果我后面再申请内存,内存管理中因为这块内存已经释放了就可以被用,这样使用你就对后面str1有影响,所谓的内存泄露相关了