c语言中的pow(x, y)的使用

Posted iqyqqqqqq

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c语言中的pow(x, y)的使用相关的知识,希望对你有一定的参考价值。

pow(10,2)用整形输出结果为0 用浮点数输出结果是100.0是什么情况
printf(“%d”,pow(10,2));输出是0
printf(“%f”,pow(10,2));输出是100.00000
这是什么情况,我用的dev cpp,难道是编译器的问题?

——————————————

不是编译器的问题。pow()返回值类型是double的。对double/float类型数据输出格式用“%d”,就是会得到奇怪的值.
为了避免这种情况,可以加上类型转换:
printf(“%d”, pow(10,2)) —–> 输出为0
printf(“%d”, (int)pow(10,2)) —-> 输出为100
这跟va_start/va_arg/va_end 分析变参有关。printf遇到“%d“,就去用int*类型去变参列表中取变量,而float/double是8个字节的,所以只取到了一半——4个字节。
再看浮点100在内存中是如何存储的:
00 00 00 00 00 00 59 40 —- 浮点100在内存中的存储(16进制,8个字节)。
用int指针去取4个字节,就得到了0.
而如果我们使用强制类型转换将浮点转换为int,就能得到正确的100.

以上是关于c语言中的pow(x, y)的使用的主要内容,如果未能解决你的问题,请参考以下文章

C语言实现输出所有的水仙花数

Python的pow函数

prolog中的幂函数

C语言作业3

C语言 不用循环和函数求 X的Y次方

c语言 指数函数怎么表达?谢谢