博客
关于我
C/C++动态分配内存
阅读量:401 次
发布时间:2019-03-06

本文共 600 字,大约阅读时间需要 2 分钟。

C:malloc和calloc来分配内存:

 

malloc函数原型

void *malloc(unsigned int size)

首先这是一个void 指针函数返回的是一个指向不定的指针,所以在调用这个函数的时候需要强转化为需要的指针类型。然后再在里面添加所需要开辟的空间大小

 

例子:

1 int * PI = NULL;2 3 PI = (int *)malloc(sizeof(int));

calloc和malloc差不多,区别就是将大小划分了一下

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

第一个参数表示要分配的个数,第二个参数表示每个个数的内存大小

 

一般推荐使用calloc因为calloc可以将分配好了的初始化为0更加安全

 

删除分配的内存:

free函数来处理

void *free(void *p)

只需要把需要释放的内存放进free中就行了。

 

重新分配内存:realloc()

void *realloc(void *p,unsigned int size);

作用是修改大小size,但是返回的是新分配的存储空间首地址,和原来的不一定相同。且只能通过指针变量引导,一旦指针指向修改,数据和内存就丢失 了。

 

 

C++:

采用new来打包处理

例子:int *a = new int(10);

删除时直接

delete a;就行了

 

转载地址:http://enfkz.baihongyu.com/

你可能感兴趣的文章
Python 内置函数笔记
查看>>
BootStrapTable 错误
查看>>
PHP 脚本不报错
查看>>
代码整洁之道小结
查看>>
悲观锁与乐观锁
查看>>
js new Date 创建时间默认是8点
查看>>
Python实现cmd命令连续执行
查看>>
罗马数字
查看>>
IO多路复用小故事
查看>>
纠错码简介
查看>>
码云 Pages 搭建
查看>>
《论可计算数及其在判定上的应用》简单理解
查看>>
中国剩余定理证明过程
查看>>
kafka告警简单方案
查看>>
java接口中多继承的问题
查看>>
java中Object.equals()简单用法
查看>>
一个小例子对多态简单的理解
查看>>
poj 2187 Beauty Contest(凸包求解多节点的之间的最大距离)
查看>>
poj 2492A Bug's Life(并查集)
查看>>
POJ 2312Battle City(BFS-priority_queue 或者是建图spfa)
查看>>