动态内存分配malloc

来源:互联网 发布:网站中文域名注册 编辑:程序博客网 时间:2024/05/21 17:47

先来段代码:

#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;}