竹逸 发表于 2022-9-19 07:23:54

这两个代码它们有什么区别么?

本帖最后由 竹逸 于 2022-9-19 07:24 编辑

为什么它们的结果不一样啊?{:5_104:}

代码一:



代码二:



wp231957 发表于 2022-9-19 07:54:17

用%d去格式化浮点数,这就是在探讨1+1为什么等于3

人造人 发表于 2022-9-19 08:30:00

你反汇编看一下

ExiaGN001 发表于 2022-9-19 08:51:08

本帖最后由 ExiaGN001 于 2022-9-19 08:53 编辑

1.%d不能拿来输出浮点数的
建议:使用 %f 或者 %lf
2.以float作为int函数的返回值可能不会触发类型转换
建议:代码1里int max(double ,double )改成double max(doiuble ,double)

竹逸 发表于 2022-9-19 08:54:04

wp231957 发表于 2022-9-19 07:54
用%d去格式化浮点数,这就是在探讨1+1为什么等于3

哈哈哈,%d貌似并不会强制转换类型,函数的返回值类型是int,是多了一步(int)a,强制转换的步骤{:10_254:}

人造人 发表于 2022-9-19 09:13:29

竹逸 发表于 2022-9-19 08:54
哈哈哈,%d貌似并不会强制转换类型,函数的返回值类型是int,是多了一步(int)a,强制转换的步骤{:10_254: ...

再看看这个吧

默认参数提升
https://www.cnblogs.com/zhanbiqiang/p/4009043.html

小灰先生 发表于 2022-9-19 09:32:02

ExiaGN001 发表于 2022-9-19 08:51
1.%d不能拿来输出浮点数的
建议:使用 %f 或者 %lf
2.以float作为int函数的返回值可能不会触发类型转换


%f

ExiaGN001 发表于 2022-9-19 09:41:26

小灰先生 发表于 2022-9-19 09:32
%f

%f和%lf都行
页: [1]
查看完整版本: 这两个代码它们有什么区别么?