【C语言天天练(九)】动态内存分配

引言:数组的元素存储于内存中连续的位置上。当一个数组被声明时。它所须要的内存在编译时就被分配。

可是,我们能够使用动态内存分配在执行时为它分配内存。

一块内存的生命周期能够分为四个阶段:分配、初始化、使用、释放。

内存的分配一般使用C函数库里的malloc函数(原型:void *malloc(size_t size))。

关于malloc函数应该注意一下几点:

1、malloc的參数就是须要分配的内存的字节数。

2、malloc所分配的是一块连续的内存。

3、分配成功。则返回指向分配内存起始地址的指针。分配失败,返回NULL指针。

4、对每一个malloc返回的指针都进行检查,是好的习惯。

内存的初始化一般要在使用之前手动进行,也能够在分配时由calloc函数一同完毕:将分配内存初始化为0。

使用就是使用分配所返回的指向内存的指针。

释放内存是为了防止内存泄露,一般使用free函数(原型:void free(void *pointer))完毕。它的參数必须是先前从malloc、calloc或realloc返回的值。向free传递一个NULL參数不会产生不论什么效果。向free传递其它參数会出错。

注意:常见的动态内存错误有下面几种

1、忘记对NULL指针进行解引用操作,即忘记对分配返回的值做推断。

2、对分配的内存进行操作时越过边界。

3、释放并不是动态分配的内存,传递给free的必须是一个从malloc、calloc或realloc返回的指针。

4、试图释放一块动态分配的内存的一部分。

5、一块动态内存被释放后被继续使用。

使用动态内存的编程总结:

1、动态内存分配有助于消除程序内部存在的限制。

2、使用sizeof计算数据类型的长度,调高程序的可移植性。

补充:calloc和realloc函数

void *calloc(size_t nmemb, size_t size);

void *realloc(void *ptr, size_t size);

calloc与malloc的差别一是前者返回指向内存的指针之前把它初始化为0.二是calloc的參数包含所需元素的数量和每一个元素的字节数。依据这些值,可以计算出总共须要分配的内存。

realloc函数用于改动一个原先已经分配的内存卡的大小。使用该函数,能够使一块内存扩大或缩小。假设原先的内存卡无法改变大小。realloc将分配还有一块正确大小的内存,并把原先那块内存的内容拷贝到新的块上。

时间: 2024-10-13 12:21:50

【C语言天天练(九)】动态内存分配的相关文章

【C语言天天练(十九)】restrict关键词

引言:在内核的系统调用函数里,经常遇到函数的参数使用restrict限定词限定的情况,下面就对该关键词做个总结. 1.restrict关键词是C99特性才添加的,因此在编译使用含有该限定词的程序时,一定要在后边添加-std=c99的标志,使得gcc能够支持c99标准. 2.restrict既然是个限定词,那么它限定什么变量呢?它只能限定指针变量!经过它限定的数据对象,表明指针时访问该数据对象的唯一且初始的方式.注意:这里的唯一表明了,由它限定的指针所指向的数据块,只能由该指针访问,不能由除它之外

C语言学习笔记--动态内存分配

1. 动态内存分配的意义 (1)C 语言中的一切操作都是基于内存的. (2)变量和数组都是内存的别名. ①内存分配由编译器在编译期间决定 ②定义数组的时候必须指定数组长度 ③数组长度是在编译期就必须确定的 (3)但是程序运行的过程中,可能需要使用一些额外的内存空间 2. malloc 和 free 函数 (1)malloc 和 free 用于执行动态内存分配的释放 (2)malloc 所分配的是一块连续的内存 (3)malloc 以字节为单位,并且返回值不带任何的类型信息:void* mallo

数据结构基础(1)--数组C语言实现--动态内存分配

数据结构基础(1)--数组C语言实现--动态内存分配 基本思想:数组是最常用的数据结构,在内存中连续存储,可以静态初始化(int a[2]={1,2}),可以动态初始化 malloc(). 难点就是数组在删除或者插入元素的时候,要移动元素的坐标不好确定.规律: 1.如果要在数组中第pos个位置插入一个元素(应该从后面开始移动) for( i=cnu;i>=pos;i--) pBase[i]=pBase[i-1]; 2.删除数组第pos位置的元素 for(i=pos+1;i<=cnu;i--)

重拾c语言之动态内存分配

动态内存分配 传统数组的缺点: 1数组长度必须事先制定,且仅仅能是长整数不能是变量 2传统形式定义的数组该数组的内存程序无法手动释放 3数组一旦定义,系统就会为该数组分配的存储空间就会一直存在直到该函数执行结束 4数组的长度不能再函数的执行的过程中动态的扩充或者缩小 5不能跨函数使用 为什么须要动态分配内存 动态内存分配内存举例--动态数组的构造 静态内存分配和动态内存分配 跨函数使用内存的问题 #include<stdio.h> void f(void) { int a[5]={0,1,2,

动态内存分配(c语言)

当声明一个数组时,它所需要的内存将在编译时就被分配.但是,数组的长度在运行时才知道.它所需要的空间取决于输入的数据.所以,存在某一个数组实际所占的内存超过编译器所分配的内存.这时候,程序就会出现问题.所以,我们可以使用动态内存分配.所谓动态内存分配即为在运行时为它分配内存. 动态内存分配函数有:malloc,calloc,realloc,free. 函数所在的头文件:#include <stdlib.h> 函数原型: void *malloc( size_t size );//字节数 void

【C语言天天练(十五)】字符串输入函数fgets、gets和scanf

引言:如果想把一个字符串读到程序中,必须首先预留存储字符串的空间,然后使用输入函数来获取这个字符串. 读取字符串输入的第一件事是建立一个空间以存放读入的字符串. char *name; scanf("%s", name); 这段代码虽然可能通过编译,但因为name可以指向任何地方,所以它的输入值可能覆盖以前name所指位置的值. 解决办法是声明一个固定大小的字符数组,或者使用C库里的分配存储空间的函数. 1.gets函数从系统标准输入获得一个字符串,读取字符串直到遇到一个换行符(\n)

【C语言天天练(六)】指针

指针变量一定要先进行初始化,然后才能使用.初始化指要对指针变量进行赋值,将一个地址值赋值给指针变量.极为常犯的错误是: int *a; *a = 12;   /*未对它进行初始化,没有办法预测12这个值将存储于什么地方*/ 分析几个指针的例子: 1.*d = 10 - *d; 两个间接访问操作.右边的间接访问作为右值使用,所以它的值是d所指向的位置所存储的值(a的值).左边的简介访问作为左值使用,所以d所指向的位置(a)把赋值符右侧的表达式的计算结果作为它的新值. 2.*&a = 2:这条语句的

C++动态内存分配

笔者介绍:姜雪伟,IT公司技术合伙人,IT高级讲师,CSDN社区专家,特邀编辑,畅销书作者,已出版书籍:<手把手教你架构3D游戏引擎>电子工业出版社和<Unity3D实战核心技术详解>电子工业出版社等. CSDN视频网址:http://edu.csdn.net/lecturer/144 C / C ++中的动态内存分配是指程序员手动执行内存分配, 动态分配的内存分配给堆,非静态和局部变量获取在Stack上分配的内存.详情查看上篇博文:C程序的内存布局. 什么是应用程序? 动态分配的

动态内存分配

1.C语言中的一切操作都是基于内存的 2.变量和数组都是内存的别名,如何分配这些内存由编译器在编译期间决定,定义数组的时候必须指定数组长度,而数组长度是在编译期就必须决定的 需求: 程序运行的过程中,可能需要使用一些额外的内存空间. malloc和free用于执行动态内存分配和释放. 1.malloc所分配的是一块连续的内存,以字节为单位,并且不带任何的类型信息 2.free用于将动态内存归还系统 注意: 1.malloc实际分配的内存可能会比请求的稍微多一点,但是不能依赖于编译器的这个行为 2