在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. 因为资源和程序源码均为可复制品,所以不支持任何理由的退款兑现,请斟酌后支付下载
声明:如果标题没有注明"已测试"或者"测试可用"等字样的资源源码均未经过站长测试.特别注意没有标注的源码不保证任何可用性