在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 }

内存图:

 


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

 

 

原文地址:http://www.cnblogs.com/MorningMaple/p/16793406.html

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长! 2. 分享目的仅供大家学习和交流,请务用于商业用途! 3. 如果你也有好源码或者教程,可以到用户中心发布,分享有积分奖励和额外收入! 4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解! 5. 如有链接无法下载、失效或广告,请联系管理员处理! 6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需! 7. 如遇到加密压缩包,默认解压密码为"gltf",如遇到无法解压的请联系管理员! 8. 因为资源和程序源码均为可复制品,所以不支持任何理由的退款兑现,请斟酌后支付下载 声明:如果标题没有注明"已测试"或者"测试可用"等字样的资源源码均未经过站长测试.特别注意没有标注的源码不保证任何可用性