news 2026/5/9 5:01:36

%d输出float类型,%f输出int类型

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
%d输出float类型,%f输出int类型

几个要注意的点:
1.并不会隐式类型转换,只是以%d的存储形式(低32位),%f(double类型的存储形式)输出
2.浮点数输出时都是以double类型的存储形式输出的,虽然在内存上以float类型存储形式存储的
3.float,double类型的存储形式遵循IEEE754标准,详情请查看IEEE754标准:double,float类型在内存中具体是怎么存的
4.像int->float,float->int等基本数据类型转换,会进行比特位的转换
5.int*->double*(所指向的空间并不进行比特位的转换),重新解释指针为:以int为一个模块操作指针->以double为一个模块操作指针

// 输出格式与类型不一致,输出结果实际上与存储有关 // 1.int以%f格式输出,结果一般为0.000000 // 2.long long 类型的很大的数,用printf(“%f”)打印出来可能为一个小数; // 3.double、float以%d格式输出(输出时,float会转化为double存储形式;%d取低32位) // (1)结果一般为绝对值很大的数(当浮点数不能精确表示时,低32位不为0) // (2)结果为0,如:xx.0、或xx.5、或xx.25等(当浮点数能精确表示时,低32位为0) #include <stdio.h> int main() { // int以%f格式输出,结果一般为0.000000 // float以%d格式输出 // 结果一般为绝对值很大的数 // 结果为0,若浮点数为xx.0、或xx.5、或xx.25等 printf("%f\n", 1); // 结果:0.000000 printf("%f\n", 0xffffffff); // 结果:0.000000 printf("%f\n", 0x3ff3ae147ae147a3); // 结果:1.230000 printf("%d\n", 2.34); // 结果:-343597384 printf("%d\n", 5.78); // 结果:1374389535 printf("%d\n", 1.0); // 结果:0.000000 printf("%d\n", 2.0); // 结果:0.000000 printf("%d\n", 2.5); // 结果:0.000000 printf("%d\n", 103.25); // 结果:0.000000 printf("----------------------------------------------------------------------------\n"); // 若想输出转换后的类型,必须强制类型转换(会容易让人混淆,因为感觉上会隐式类型转换,但实际上 // 没有"=",不会自动转换) printf("%f,%d\n", (double)1, (int)1.0); // 结果:1.000000,1 printf("----------------------------------------------------------------------------\n"); // int*->double*,只是指针类型的转换(所指向的空间并不进行比特位的转换)。 int c = 1; int *p_int = &c; double *p_double = NULL; p_double = (double*)p_int; printf("llx:0x%llx\n", *p_double); // 查看double指向的内存空间有什么数据,我这里内存中存了:0x1b00000001 printf("%f,%d\n", *p_double, *p_double); // 结果:0.000000,1 // 实际上int的存储结构没变,将double指向的内存空间的数据(0x1b00000001)以%f格式输出 // 应该这么转 double c2 = (double)c; // 转成了了double类型的存储形式(进行了比特位的转换) double *p_double2 = &c2; printf("llx:0x%llx\n", c); // 内存中存了(比特位):0x1 printf("llx:0x%llx\n", *p_double2); // 内存中存了(比特位):0x3ff0000000000000 printf("%f,%d\n", *p_double2, *p_double2); // 结果:1.000000,0 printf("----------------------------------------------------------------------------\n"); }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/3 2:26:22

CentOS 8 完整实现 Rsyslog 日志写入 MySQL 数据库

目录 一、安装 Rsyslog 依赖包 二、MySQL 端初始化 三、配置 Rsyslog 核心规则&#xff08;日志写入 MySQL&#xff09; 1.编辑 rsyslog 配置文件 2.在文件末尾添加以下完整配置 四、重启服务 五、故障排查 1.校验 Rsyslog 配置语法&#xff08;最常用&#xff09; 2.…

作者头像 李华
网站建设 2026/5/6 12:10:36

手把手教你用Miniconda配置PyTorch环境,支持GPU调用

手把手教你用Miniconda配置PyTorch环境&#xff0c;支持GPU调用 在深度学习项目开发中&#xff0c;一个常见的场景是&#xff1a;你刚从GitHub拉下一个热门的PyTorch模型代码&#xff0c;满怀期待地运行python train.py&#xff0c;结果却抛出一连串依赖错误——有的包版本不兼…

作者头像 李华
网站建设 2026/4/25 2:38:33

车路协同十年演进(2015–2025)

车路协同十年演进&#xff08;2015–2025&#xff09; 一句话总论&#xff1a; 2015年车路协同还是“孤立的V2X概念实验室测试”&#xff0c;2025年已进化成“5G-A/6G北斗路侧感知云控平台大模型实时协同”的全域车路云一体生态&#xff0c;中国从标准跟随者跃升全球领跑者&…

作者头像 李华
网站建设 2026/5/8 9:49:30

Doris基于 Arrow Flight SQL 的高速数据传输链路

好的&#xff0c;Doris 结合 Apache Arrow 的 Flight SQL 协议&#xff0c;构建了一条高效的数据传输链路&#xff0c;显著提升了大数据量交互的性能。以下是该链路的核心机制与优势&#xff1a;核心机制列式存储与传输Doris 的存储引擎原生采用列式结构&#xff0c;与 Arrow 的…

作者头像 李华