动态内存分配malloc

先来段代码:

#include<cstdio>
#include<malloc.h>
int main(){
    int a[5]={4,10,2,8,6};
    int len;
    printf("请输入你要分配的数组的长度:len=");
    scanf("%d",&len);
    int * pArr = (int *)malloc(sizeof(int) * len); //sizeof(int)返回的是整形的字节数
    //程序请求系统为其分配20字节空间的内存
    //malloc函数只能返回第一个字节地址
    //强制类型转换告诉编辑器返回的是整形的地址
    //所谓整形地址就是说第一个字节的地址+1是跨过了四个字节

    /*
        这个动态的内存是根据用户的需求来分配的,并且可以动态释放
    */
    pArr[0] = 4;
    pArr[1] = 5;
    pArr[2] = 6;
    pArr[3] = 6;
    pArr[4] = 6;
    for(int i = 0;i<5;i++){
        printf("%d ",*(pArr+i));

    }
   
    free(pArr);
    //把pArr所代表的动态分配的20个字节的内存释放
    printf("释放之后:%d\n",*pArr);

return 0;
}


malloc()函数只需要一个参数,就是用户需要分配多少内存。并且返回第一个字节的地址。

假如你要自己利用动态内存的方式创建一个int型的数组,那么先想好你要创建多长的。例如上述所示的代码,我要创建长度为5的int型数组。那么就可以表示成:

malloc(sizeof(int)*5);


但这仅仅是创建了20个字节的空间,并没有指定这是int型还是其他类型的,因此我们要指定这是int型的。也就是说第一个字节地址+1,就跨过了4个字节。

因此需要 (int *)malloc(sizeof(int )*5) 这样来进行强制转换。


这样一来:

int * p = (int *)malloc(sizeof(int)*5);

p就指向了20个字节的动态内存的首地址。p+1就指向了下一个,即相当于int a[5]中的a[1]的首地址。


free(首地址) 就可以释放掉内存了

需要注意的是:动态分配内存,必须手动释放掉才可以。否则只能当整个程序彻底终止的时候才能释放。

因此上述代码中,释放掉内存后,*pArr就变成了一个“垃圾数”。

希望大家可以认真仔细的看一下我上面所说的每一句话,非常有助于你理解动态分配内存的知识。



下面在写一个利用动态内存分配的小栗子(其实链表的创建也是用的malloc):

#include<cstdio>
#include<malloc.h>
struct Student{
    int sid;
    int age;

};
struct Student * CreateStudent(){
    struct Student * p = (struct Student *)malloc(sizeof(struct Student));
    p->age = 18;
    p->sid = 151;
    return p;
};
void ShowStudent(struct Student * p){
    printf("%d %d\n",p->age,p->sid);
    
}
int main(){
    struct Student * ps;
    ps = CreateStudent();
    ShowStudent(ps);
    return 0;
}





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值