C 存储空间的分配和释放

存储空间的分配和释放

动态存储分配的数据结构

头文件  #include<stdlib.h>

用四个函数来进行动态储存分配{ malloc(),calloc(), realloc()},动态存储释放:free()。

1.malloc(),动态分配一段内存空间

void *malloc(unsigned int size)

用sizeof()来计算申请空间的大小

例:int *p=(int *)malloc(sizeof(int))

申请一个Int类型长度的存储空间,并将分配的地址空间地址转化成int类型地址,赋给所定义的指针变量P.

2.calloc(),动态分配连续内存空间

void *calloc(unsigned int n,unsigned int size);

内存申请n个长度的size字节的存储空间,并返回改存储空间的起始位置,n为元素的个数,size为元素存储长度。

例:int*p=(int*)calloc(10,sizeof(int));

相当于  int *p=(int *)mallo(sizeof(int)*10);

比如:用calloc和malloc 函数分配数组26个字符的字符数

char *ch1=(char*)calloc(26,sizeof(char));

char *ch2=(char*)malloc(sizeof(char[26]);

3.realloc改变指针指向空间的大小

void *realloc (void *prt,size_t size)

例:

改变一个浮点型空间大小为整型大小

fDouble=(double*)malloc(sizeof(double));

iInt=realloc(fDouble,sizeof(int));

程序:double 型改为short

4.free(),释放存储空间

void free (void *p)

无返回值

例:int *a;

*a=(int *)calloc(20,sizeof(int));

a=b;

b++;

free(a);

时间: 2025-01-18 13:01:02

C 存储空间的分配和释放的相关文章

内存管理概述、内存分配与释放、地址映射机制(mm_struct, vm_area_struct)、malloc/free 的实现

http://blog.csdn.net/pi9nc/article/details/23334659 注:本分类下文章大多整理自<深入分析linux内核源代码>一书,另有参考其他一些资料如<linux内核完全剖析>.<linux c 编程一站式学习>等,只是为了更好地理清系统编程和网络编程中的一些概念性问题,并没有深入地阅读分析源码,我也是草草翻过这本书,请有兴趣的朋友自己参考相关资料.此书出版较早,分析的版本为2.4.16,故出现的一些概念可能跟最新版本内核不同.

ZFS空间管理(分配、释放原理)

一个文件系统的空间管理,常见的技术大致有两种,bitmap和tree方式. bitmap是将文件系统所有管辖的空间细化成block(windows叫cluster),每一个block对应一个二进制位,两种状态分别表示自由/已分配.将这些二进制位集合在一起,就是bitmap.当需要分配空间时,在bitmap中查找连续的自由位,分配后,再置成已分配就可以了:释放时,将对应位置为可分配即可. tree方式是以extent的记录来描述自由/已分配空间的状态,如果以表示自由空间的tree来说,有可能是由一

per-CPU分配和释放单页框

内核经常请求和释放单个页框.为了提升系统性能,每个内存管理区定义了一个"每CPU"页框高速缓存.所有"每CPU"高速缓存包含一些预先分配的页框,它们被用于满足本地CPU发出的单一内存请求. 为每个内存管理区和每CPU提供了两个高速缓存:一个热高速缓存,它存放页框中所包含的内容很可能就在CPU硬件高速缓存中:还有一个冷高速缓存. 在内存管理区中,分配单页使用per-cpu机制,分配多页使用伙伴算法,结构图如下: 1.相关结构体 zone结构体中pageset成员指向内

如何在MD(d)和MT(d)工程间正确分配和释放动态内存

MD(d)和MT(d) MD(d)和MT(d)是windows下VC开发的两个编译选项,表示程序的运行时库编译选项. /MT是"multithread, static version" 意思是多线程静态的版本,定义了它后,编译器把LIBCMT.lib安置到OBJ文件中,让链接器使用LIBCMT.lib 处理外部符号. /MD是"multithread- and DLL-specific version",意思是多线程DLL版本,定义了它后,编译器把MSVCRT.li

堆空间的分配与释放

堆空间的分配和释放 #include <stdlib.h> malloc.calloc.realloc.free malloc void *malloc(size_t size); 功能:在堆中分配 size 字节的连续空间 参数:size_字节数 返回值:成功返回分配空间的首地址,失败返回 NULL free void free(void *ptr); 功能:释放由 malloc.calloc.realloc 分配的空间 参数:ptr_空间的首地址 返回值:无 注意: 1.每个空间只能释放一

Delphi的分配及释放---New/Dispose, GetMem/FreeMem及其它函数的区别与相同

转载自:http://www.cnblogs.com/qiusl/p/4028437.html?utm_source=tuicool 我估摸者内存分配+释放是个基础的函数,有些人可能没注意此类函数或细究,但我觉得还是弄明白好. 介绍下面内存函数之前,先说一下MM的一些过程,如不关心课忽略: TMemoryManger = record GetMem: function(Size: Integer): Pointer; FreeMem: function(P: Pointer): Integer;

c++跨动态库DLL的内存分配与释放问题

先说结论: 1.如果两个DLL(或者EXE调用DLL)的CRT链接均为MD,则可以跨动态库分配和释放,如果一个是MT,另外一个是MD则会有问题. 2.利用虚函数的动态绑定技术,动态绑定分配释放内存的new和delete等,可以解决这个问题,例如shared_ptr.但如果shared_ptr包装是vector等类型,在调用和被调用中都涉及到vector的修改的话,仍然会有问题,因为两个地方都会有释放和分配. 似乎最好的办法还是用原始指针加数组长度的方式传递. 参见下面两个文章. 1.跨DLL的内

c++动态内存分配与释放

一般变量的分配与释放 #include<iostream> using namespace std; int main() {     int *p = new int(4);     *p = 10;     cout << *p << endl;     delete p;     return 0; } 数组变量的分配与释放 #include #include<iostream> using namespace std; int main() {   

C++中指针数组的分配与释放

C++中可用new和delete关键字分配和释放内存,但是如果遇到指针数组(或指向指针的指针),分配和释放必须慎重,不然容易造成内存泄漏. 下面用一段代码给出如何使用指向指针的指针来分配和释放内存: int n; cin>>n; //分配内存 char** pStrArray = new char*[n]; for (int i=0;i<N;i++) { pStrArray [i] = new char[5]; cin>>pStrArray [i]; } doOperator