2-6 C浮点数指针运算案例

1.0 浮点数指针


float f= 1.2f:如何将它对应的4个字节地址空间的数值以十六进制打印出来?

数据在所有计算机中都是以二进制形式存储的,然后以8个位为一个单元称作"字节" ,作为计

量和运算处理单元,比如我们说一个文件大小是1MB,指的是1M字节;

在计算机中,每个字节都有它对应的地址,类似于门牌号CPU通过地址来访问这个字节空间


2.0 引入数据类型


对于计算机硬件系统,二进制01数据没有任何意义 ,为了有效的组织管理这些数据,人为的规
定了数据类型去解释这些二进制数据
:


3.0 应用案例


cpp 复制代码
int main(void)
{
	float f = 1.2f;
	uint8_t *p;
	p = (uint8_t *)&f;
	printf("*p = %#x.\n",*p);
	p++;
	printf("*p = %#x.\n",*p);
	p++;
	printf("*p = %#x.\n",*p);
	p++;
	printf("*p = %#x.\n",*p);
	return 0;
}

运行以上程序输出如下结果:


uint8 tvalue[4]={0x9A,0x99,0x99,0x3F};如何转换为float类型数值并打印?

案例分析:

  1. 可以定义float *f,用它来保存数组的首地址
  2. 但是此时由于类型不匹配,需要强制类型转换
  3. 然后可以使用*f去访问这段内存空间了,调用printf函数
cpp 复制代码
int main(void)
{
	uint8_t value[4] = {0x9A, 0x99, 0x99, 0x3F};
	float *f = (float *)value;
	printf("*f = %.1f\n",*f);
	return 0;
}

运行以上程序输出如下结果:

...

相关推荐
Tiger_shl16 分钟前
【.Net技术栈梳理】08-控制反转(IoC)与依赖注入(DI)
开发语言·.net·.netcore
Tiger_shl18 分钟前
【.Net技术栈梳理】10-.NET Core 程序的执行
开发语言·.net·.netcore
薄荷撞~可乐40 分钟前
C#高并发与并行理解处理
开发语言·c#
孤廖1 小时前
【算法磨剑:用 C++ 思考的艺术・Dijkstra 实战】弱化版 vs 标准版模板,洛谷 P3371/P4779 双题精讲
java·开发语言·c++·程序人生·算法·贪心算法·启发式算法
sali-tec1 小时前
C# 基于halcon的视觉工作流-章33-矩状测量
开发语言·人工智能·算法·计算机视觉·c#
酷炫码神2 小时前
第 2 篇:Java 入门实战(JDK8 版)—— 编写第一个 Java 程序,理解基础运行逻辑
java·开发语言·策略模式
像风一样自由20202 小时前
Go语言详细指南:特点、应用场景与开发工具
开发语言·后端·golang
半夏知半秋2 小时前
基于跳跃表的zset实现解析(lua版)
服务器·开发语言·redis·学习·lua
Wyc724092 小时前
Lua语言基础笔记
开发语言·笔记·lua
编码浪子6 小时前
趣味学RUST基础篇(智能指针_结束)
开发语言·算法·rust