动态内存分布

在C中,不同数据在内存中分配说明:

 动态内存分配的相关函数:

 

 

 void *只是提供一个纯地址,不指向任何数据,如下图的*p3


void指针类型:

 即指针类型为void,不能用*p的方式来取得这个p所指向的变量值,因为它本身就是个纯地址。

 a本身是个int整数

这里把a的纯地址赋值给了p3

这里是把int *类型的a的值赋值给了void *类型的p3

有些版本的编译器会自动转换,等价于p3 = (void *) &a

有些需要自己强制转换。。。

实例:

复制代码
 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 
 4 int main(){
 5     void check(int *);  //函数声明(函数定义写在下面了,写上面就不用声明)
 6     int* p, i;
 7     //在堆中开辟了20个字节的连续空间
 8     //malloc(5*sizeof(int))本身返回的是void *类型,希望用int *的p来接收,所以要强转一下
 9     p = (int*)malloc(5*sizeof(int));    //void * ->int *[高版本会自动转换]
10     for ( i = 0; i < 5; i++){   //移动地址赋值
11         printf("请输入第%d个成绩:", i+1);
12         scanf("%d", p + i);
13     }
14     check(p);   //调用栈
15     free(p);    //销毁堆区p指向的空间(就是内存图内保存5个int的那个空间)
16     return 0;
17 }
18 
19 void check(int *p){
20     int i;
21     printf("\n不及格的成绩有:");
22     for ( i = 0; i < 5; i++){
23         if (p[i]<60){
24             printf("%d ", p[i]);
25         }
26     }
27 }
复制代码

内存图:

 


动态内存分配的基本原则:

 

 

posted @   Morning枫  阅读(22)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示