深刻理解C指针的存储位置

以下将要说明一下指针存在栈空间还是堆空间的话题:

废话少说,直接上代码

#include <stdio.h>
#include <stdlib.h>

char *sc_malloc(int size)
{
	char *p = (char*)malloc(sizeof(char)*size);

	return p;
}

void sc_free(char *p)
{
	if(p)
	{
		free(p);

		printf("[%s]\n", p);
		printf("[%p]\n\n", p);

		p = NULL;

		printf("[%s]\n", p);
		printf("[%p]\n", p);
	}
}

int main(int argc, char const *argv[])
{
	char *p = sc_malloc(100);
	sc_free(p);
	
	if (p == NULL)
	{
		printf("free sucess\n");
	}
	printf("[%s]\n", p);
	printf("[%p]\n", p);
	return 0;
}

上述代码的执行结果是什么呢?

预想是这样的

[root@6b4ce1faff56 sc_cunit_test]# ./test            
[]
[0x2191010]

free sucess
[(null)]
[(nil)]
[]
[(null)]

事实上

可是事实不是这样的,以下是真正运行的结果

[root@6b4ce1faff56 sc_cunit_test]# ./test            
[]
[0x2191010]

[(null)]
[(nil)]
[]
[0x2191010]

思考

为什么在调用 sc_free 释放并且将指针 p 置空在之后,在main函数中,打印p的内容为空,地址不为空呢????

事实是这样子的:
在这里插入图片描述
p指针的位置是存储在栈空间的,而指针p指向的空间是在堆上的,调用 free 函数,只能释放掉堆空间的指针,在调用sc_free() 函数,即是在函数内部将p置为NULL,但是对栈空间的变量操作,做为返回值是不生效的。所以导致了,在main函数中调用 sc_free 之后,发现判断p == NULL ,不成功。
所以在调用sc_free之后,尽量手动将 p 置空,而不是在 sc_free 内部置空。

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值