首页 > 系统相关 >动态内存分布

动态内存分布

时间:2022-10-15 16:35:54浏览次数:47  
标签:p3 int void 地址 分布 动态内存 check

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

内存图:

 


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

 

 

标签:p3,int,void,地址,分布,动态内存,check
From: https://www.cnblogs.com/MorningMaple/p/16793406.html

相关文章

  • docker-compose 实现minio分布式存储服务
    minio是一个非常流行的高性能存储服务,云服务器使用得非常多。现在minio的更新非常迅速,三天两头就会更新版本,为了学习minio,了解最近特性,使用docker进行部署安装就非常方便。......
  • 我们能从后验分布中学到什么?贝叶斯后验的频率解释
    假设我们从未知分布q中观察到N个独立且同分布的(iid)样本X=(x1,...,xN)。统计学中的一个典型问题是“样本集X能告诉我们关于分布q的什么信息?”。参数统计......
  • 表与索引分布在不同表空间,删除其中一个表空间的测试
    文档课题:表与索引分布在不同表空间,删除其中一个表空间的测试.数据库:oracle11.2.0.464位1、环境准备sys@ORCL2022-10-1409:49:15>createtablespaceapp1tbsdatafile'......
  • C/C++ 为什么要使用动态内存?
    为什么要使用动态内存?1.按需分配,根据需要分配内存,不浪费;2.被调用函数之外需要使用被调用函数内部的指针对应的地址空间;3.突破栈区的限制,可以给程序分配更多的内存......
  • 钡铼技术发布新一代OPC UA分布式 I/O控制器BL200pro助力工业物联网的数字化
    钡铼技术发布新一代OPCUA分布式I/O控制器BL200pro助力工业物联网的数字化钡铼技术推出了具有兼容ModbusTCP、MQTT、OPCUA通讯协议的新一代分布式I/O控制器,BL200PRO是......
  • 工业4.0数据采集神器OPC UA分布式IO控制器BL200PRO
    钡铼技术发布新一代OPCUA分布式I/O控制器BL200pro助力工业物联网的数字化钡铼技术推出了具有兼容ModbusTCP、MQTT、OPCUA通讯协议的新一代分布式I/O控制器,BL200PRO是一......
  • Jmeter分布式
    Jmeter分布式执行原理Jmeter分布式测试时,其中一台作为控制机,其他机器作为代理机执行时控制机把脚本发送到每台代理机,代理机执行脚本,执行时不启动Jmeter界面,可理解为......
  • 如何用Zookeeper来实现分布式锁?
    如何用Zookeeper来实现分布式锁?​​什么是Zookeeper临时顺序节点?​​​​Znode分为四种类型:​​​​Zookeeper分布式锁的原理​​​​获取锁:​​​​释放锁:​​什么......
  • Python爬虫之scrapy_redis原理分析并实现断点续爬以及分布式爬虫
    scrapy_redis原理分析并实现断点续爬以及分布式爬虫学习目标了解scrapy实现去重的原理了解scrapy中请求入队的条件掌握scrapy_redis基于url地址的增量式单机爬虫掌握scr......
  • 分布式锁-zookeeper
    前言在平时我们对锁的使用,在针对单个服务,我们可以用Java自带的一些锁来实现,资源的顺序访问,但是随着业务的发展,现在基本上公司的服务都是多个,单纯的Lock或者Synchronize......