码迷,mamicode.com
首页 > 编程语言 > 详细

数据结构与算法基础之malloc()动态分配内存概述

时间:2019-07-27 18:29:34      阅读:119      评论:0      收藏:0      [点我收藏+]

标签:要求   概述   size   第一个   动态   转化   系统   null   span   

动态内存分配和释放:

  动态构造一维数组:

    假设动态构造一个Int型数组:

1 int *p = (int *)malloc(int len);
2 //还可以写作:
3 int *p = (int *)malloc(sizeof(int)*len);
4 int *p = (int *)malloc(sizeof(len));
5 数据类型 *p = (数据类型 *)malloc(sizeof(数据类型)*长度);

  1.malloc只有一个int型的形参,表示要求系统分配的字节数

  2.malloc函数的功能是请求系统分配len个字节的内存空间,如果请求成功,则返回第一个字节的地址,如果请求失败,则返回NULL。

  3.malloc函数能且只能返回第一个字节的地址,所以我们需要把这个无任何实际意义的第一个字节的地址(俗称干地址)转化成一个有实际意义的地址,nalloc函数前面必须加(数据类型 *),表示把这个无实际意义的第一个地址转化为相应类型的地址。如:

1 int *p = (int *)malloc(50);

  表示将系统分配好的50个字节的第一个字节的地址转化为int *类型的地址,更准确的说是把第一个字节的地址转化为四个字节的地址,这样p就指向了第一个的四个字节,p+1就指向了第2个的四个字节,p+i就指向了第i+1个的四个字节。p[0]就是第一个元素,p[i]就是第i+1个元素。

 

1 double *p = (double *)malloc(80);

  表示将系统分配好的80个字节的第一个字节的地址地址转化为double*类型的地址……

 

程序运行结束需要释放内存

1 free(p) ;//释放p所指向的内存,而不是释放p本身所占用的内存

 

 1 #include<stdio.h>
 2 # include <malloc.h>
 3 int main(){
 4     int a[5]={1,2,3,4,5};//静态分配
 5     int len;
 6     printf("输入你需要分配的数组的长度:len=");
 7     scanf("%d",&len);
 8     int *pArr = (int *)malloc(sizeof(int) * len);
 9     //*pArr = 4;  //pArr等价于数组名a,*pArr等价于a[0]
10    // pArr[1]=10;//类似于a[1]=10
11     //所以使用动态分配内存后,可以将pArr当作数组名处理了,因为它是第一个元素的地址
12     for(int i=0;i<len;i++){
13         scanf("%d",&pArr[i]);
14     }
15     for(i=0;i<len;i++){
16         printf("%d\n",*(pArr+i));
17     }
18     free(pArr);//把pArr所代表的动态分配的20个字节的内存释放
19     return 0;
20 }

 

数据结构与算法基础之malloc()动态分配内存概述

标签:要求   概述   size   第一个   动态   转化   系统   null   span   

原文地址:https://www.cnblogs.com/sunbr/p/11256126.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!