一、存储模型1、static ,suto、extern 二、内存管理1、动态内存(1)、C/C++定义了4个定义内存区间:代码区 / 全局变量与静态变量区 / 局部变量区即栈区(字符串常量)/ 动态存储区,即堆区。(2)、静态储出...
                
一、存储模型
1、static ,suto、extern
二、内存管理
1、动态内存
(1)、C/C++定义了4个定义内存区间:
- 代码区 / 全局变量与静态变量区 / 局部变量区即栈区(字符串常量)/ 动态存储区,即堆区。
 
(2)、静态储出分配
- 通常定义变量,编译器在编译时都可以根据该变量的类型知道所需内存 空间的大小,从而系统在适当的适合为他们分配确定的存储空间。
 
(3)、在栈上创建。在执行函数时,函数内局部变量的存储单元都可以在栈上创建,函数执行结束时这些存储单元自动被释放。栈内存分配运算内置与处理器的指令集中,效率很高,但是分配的内存容量有效。
2、动态存储分配
(1)、有些操作对象只有在程序运行才能确定,这样编译器在编译时就无法为他们预留存储空间,只能在程序运行时,系统根据运行时的要求进行内存分配,这种 方法称为动态存储分配。
— 所有动态存储分配都在堆区中进行。
— 从堆上分配,亦称为动态内存分配。程序在运行的时候用malloc申请任意多少的内存,程序员自己负责在何时用free释放内存。动态内存的生存期有我们决定,使用非常灵活,但问题也最多。
(2)、当程序运行到需要一个动态分配的变量或对象时,必须向系统申请取得堆中的一块所需大小的存存储空间,用于存储该变量或对象。当不在使用该变量或则变量时,也就是它的声明周期结束时,要显示释放它所占用的存储空间,这样系统就能对该堆空间进行再次分配,做到重复使用有限的资源。
(3)、堆区是不会自动在分配时做初始化的(包括清零),所以必须用初始化式(initializer)来显式初始化。
(4)、malloc/free
void * malloc(size_t num)
void free(void *p)
— malloc函数本身并不识别要申请的内存是什么类型,它只关心内存的总字节数。
— malloc申请到的是一块连续的内存,有时可能会比所申请的空间大。其有时会申请不到内存,返回NULL。
— malloc返回值的类型是void* ,所以在调用malloc是要显示地进行类型转换,将void*转换成所需要的指针类型。
— 如果free的参数是NULL的话,没有任何效果。
— 释放一块内存中的一部分是不被允许的。
3、动态内存分配的问题
1、分配好了内存后,往该内存空间写入数据的大小不能超过该内存空间的大小,
本文标题为:C语言 _ 内存管理
				
        
 
            
        基础教程推荐
- C语言植物大战数据结构二叉树递归 2023-04-09
 - 05-C语言进阶——动态内存管理 2023-11-20
 - g++: const 丢弃限定符 2022-10-07
 - character-encoding – Linux中最常见的C语言编码(和Unix?) 2023-11-21
 - VisualStudio2010安装教程 2023-01-05
 - Qt数据库应用之实现通用数据库请求 2023-03-18
 - C语言数组长度的计算方法实例总结(sizeof与strlen) 2023-04-26
 - 利用QT设计秒表功能 2023-05-30
 - C语言的三种条件判断语句你都了解吗 2023-03-05
 - 纯C++代码详解二叉树相关操作 2023-05-15
 
    	
    	
    	
    	
    	
    	
    	
    	
						
						
						
						
						
				
				
				
				