这两个代码它们有什么区别么?
本帖最后由 竹逸 于 2022-9-19 07:24 编辑为什么它们的结果不一样啊?{:5_104:}
代码一:
代码二:
用%d去格式化浮点数,这就是在探讨1+1为什么等于3 你反汇编看一下
本帖最后由 ExiaGN001 于 2022-9-19 08:53 编辑
1.%d不能拿来输出浮点数的
建议:使用 %f 或者 %lf
2.以float作为int函数的返回值可能不会触发类型转换
建议:代码1里int max(double ,double )改成double max(doiuble ,double)
wp231957 发表于 2022-9-19 07:54
用%d去格式化浮点数,这就是在探讨1+1为什么等于3
哈哈哈,%d貌似并不会强制转换类型,函数的返回值类型是int,是多了一步(int)a,强制转换的步骤{:10_254:} 竹逸 发表于 2022-9-19 08:54
哈哈哈,%d貌似并不会强制转换类型,函数的返回值类型是int,是多了一步(int)a,强制转换的步骤{:10_254: ...
再看看这个吧
默认参数提升
https://www.cnblogs.com/zhanbiqiang/p/4009043.html
ExiaGN001 发表于 2022-9-19 08:51
1.%d不能拿来输出浮点数的
建议:使用 %f 或者 %lf
2.以float作为int函数的返回值可能不会触发类型转换
%f 小灰先生 发表于 2022-9-19 09:32
%f
%f和%lf都行
页:
[1]