12-指针和动态内存-malloc calloc realloc free

一、视频笔记:

Malloc- void* malloc(size - size)

是一个通用的函数,库函数。所做的事情仅仅是,从 上找到空闲的内存。为你预留的空间然后通过指针返回给你。

Void *p = malloc(10 *sizeof(int))

总共需要的字节数是:单元数量*每个单元的字节数。

指针类型转换:写成int *p 而不是 void *p

Calloc - void *Calloc(size_t num ,size_t size)

也是返回一个void指针。接收两个参数,1:特定类型的元素的个数 2:类型的大小

Int *p = (int*)calloc(3 , sizeof(int)) 1:数量 2:类型的大小

Realloc - void* realloc(void* ptr , size_t size)

扩展。接收两个参数:1 :指向已分配内存的起始地址的指针 2 :新的内存块的大小

当我们想要的内存块可能比想要的要大,开新的,旧的有有剩余且有连续的内存,会拓展之前的块。拷贝释放。

**Free - free(A);**入参是内存的起始地址。

任何分配了的动态内存在程序结束之前会一直占据着内存,除非显示的释放它。

传入恰当的参数,realoc 可以作为free或malloc的替代品。

Malloc Calloc 两者区别:

Malloc:分配完内存后不会对其进行初始化,因此如果你没有得到值,你将会得到一些随机值(垃圾)。

Calloc:会对其初始化为0。

\]里面的值不能是一个变量,会大致编译错误。要先知道数组的大小: Int \*A =malloc(**(int\*)**n\*sizeof(int)); 这里要有int类型的强制转换,否则会编译错误。 Int \*B = (int\*)realloc(A,0);相当于free(A) ## 二、代码示例: 我用vs运行有错误,下面写下就示例看下 int main() { int n; printf("Enter size of array\n"); scanf_s("%d", &n); int* A = (int*)calloc(n, sizeof(int)); for (int i = 0; i < n; i++) { A[i] = i + 1; } //free(A); //free空了之后还是可以修改A[2]地址的值。但是不是在所有机器上都行。 //还是请确保只是用分配的内存,否则会像在黑暗中射击,不知道会发生什么 //A[2] = 6; int* B = (int*)realloc(NULL, n * sizeof(int)); //可以用realloc代替free printf("Prev block address = %d, new address = %d\n", A, B); for (int i = 0; i < n; i++) { printf("%d ", A[i]); } }

相关推荐
_F_y7 分钟前
list简单模拟实现
c++·list
前进的程序员11 分钟前
C++ 在 Windows 和 Linux 平台上的开发差异及常见问题
linux·c++·windows
martian66542 分钟前
医学影像系统性能优化与调试技术:深度剖析与实践指南
开发语言·系统安全·dicom
y1021210443 分钟前
Pyhton训练营打卡Day27
java·开发语言·数据结构
daiwoliyunshang1 小时前
哈希表实现(1):
数据结构·c++
pystraf1 小时前
模板分享:网络最小费用流
c++·算法·图论·网络流
AA-代码批发V哥1 小时前
Java类一文分解:JavaBean,工具类,测试类的深度剖析
java·开发语言
chilavert3181 小时前
从RPA项目说说RPC和MQ的使用。
开发语言·qt·rpc·rabbitmq
thisiszdy1 小时前
<C++> MFC自动关闭对话框(MessageBoxTimeout)
c++·mfc
越城1 小时前
深入理解二叉树:遍历、存储与算法实现
c语言·数据结构·算法