C语言关于变量,指针变量,malloc和free,堆栈相关的调试总结

前言:最近复习C语言,遇到一些很常见但是又很基础的问题,巩固一下查漏补缺...

一、int型变量和int型指针变量所占空间大小

x64平台运行如下代码:

char a = 0;
int b = 0;
char *c = &a;
int *d = &b;
printf("char型变量a所占字节数为: %d\n", sizeof(a));
printf("int型变量b所占字节数为: %d\n", sizeof(b));
printf("char型指针变量c所占字节数为: %d\n", sizeof(c));
printf("int型指针变量d所占字节数为: %d\n", sizeof(d));

运行结果如下:

指针变量存储的是对应变量的地址!!!在x64平台下变量的地址范围是非常大的!因此指针变量的大小为8字节!(64位)

而对应的char型变量和int型变量分别对应大小为1字节和4字节。

二、数组名称的含义和sizeof(数组名)的结果

运行如下代码:

    int myArr[5] = {1,2,3,4,5};
    printf("测试数组名的地址: %d\n", &myArr);
    printf("测试数组的地址序列为:\n");
    for(int i = 0; i < 5; i++)
    {
        printf("%d ", &myArr[i]);
    }
    printf("  测试数组所占空间大小为: %d\n",sizeof(myArr));

运行结果如下:

数组名即为数组首元素的地址!sizeof函数可以传参数组名,返回值即为该数组所占空间大小(20字节)

三、malloc内存分配调试结果

运行如下代码:

int myArr[5] = {1,2,3,4,5};
int *tempArr = (int *)malloc(sizeof(myArr));
printf("  tempArr所占空间为: %d\n", sizeof(tempArr));
printf("tempArr指针的地址为:%d\n",&tempArr);
printf("\n堆中新建数组的地址序列为:\n");
for(int i = 0; i < 5; i++)
{
    printf("%d ", &tempArr[i]);
}
free(tempArr);

运行结果如下:

上面运行结果可以知道,通过malloc函数在堆中开辟了20个字节大小int型数组的空间,栈中(tempArr地址是6422008)定义了一个int型指针变量,这个指针变量所占空间大小为8字节,它指向(给它赋值)堆中开辟空间的首地址!!!

接下来整个活,如果我将tempArr指向myArr(重新赋值),运行如下代码:

    int myArr[5] = {1,2,3,4,5};
    int *tempArr = (int *)malloc(sizeof(myArr));
    
    tempArr = myArr;
    printf("  tempArr所占空间为: %d\n", sizeof(tempArr));
    printf("tempArr指针的地址为:%d\n",&tempArr);
    printf("\n堆中新建数组的地址序列为:\n");
    for(int i = 0; i < 5; i++)
    {
        printf("%d ", &tempArr[i]);
    }
    
    free(tempArr);

运行结果如下:

可以发现此时vscode在free函数卡死,原因很简单,tempArr重新指向了栈中的数组,而栈中的内容是无法手动free的,此时通过malloc开辟的空间并没有真正的free掉,并且造成了内存泄漏!!!

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值