为什么不包含头文件时fabs()函数返回的结果错得很离谱?为什么一定要先声明后调用?

本文通过两个案例探讨了在C语言编程中,浮点数运算和函数声明不当可能导致的错误。案例一展示了使用fabs函数时,由于类型转换不当导致的计算误差。案例二则说明了未正确声明函数导致的参数类型错误,从而引发的运行时错误。文章最后给出了正确的解决方案和原因分析。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

案例一

先来看一个案例:

int main()
{
	int n = 0;
	
	float x = -123.456f;
	
	float y = fabs(x);
		
	while(1)
	{
		y = y + 1;
		
		n++;
	}
}

调试环境:

KEIL_MDK V4.72

你觉得执行完“float y = fabs(x);”这一行之后,y的值等于多少?是123.456吗?

执行结果

先看看代码:

 

再看看编译过程:

似乎没有问题。不就一个编译告警吗?又不是error,先不管它,能生成bin就好。

 

调试运行一下:

咦,y怎么变得那么大啦?

再看看,

没错啊,y的值就是这么大啊。奇怪了。。。。。。

 

 

案例二

在main.c之外,还有一个function模块。

头文件function.h的代码为:

#ifndef FUNCTION_H
#define FUNCTION_H

float GetMaxFloat(float x, float y);

#endif

源文件function.c的代码为:

#include "function.h"

float GetMaxFloat(float x, float y)
{
	float z;
	
	if (x > y)
	{
		z = x;
	}
	else
	{
		z = y;
	}
	
	return z;
}

在main()函数中增加以下几行代码:

		float a = 12.3f;
		float b = 45.6f;
		float c = GetMaxFloat(a, b);

工程情况如下:

执行完c=GetMaxFloat(a,b);之后,c的值是我们所期望的45.6吗?

来,调试一下看看:

a和b的值都是对的,但c的值错得很离谱啊。

 

解决对策

包含对应的头文件,消除编译告警!

 

现在变成这个样子:

注意:增加两行include之后,左边的黄色感叹号也没有了。

再看看运行结果:

现在,y和c的值都对啦!!

 

原因分析

编译器在没有找到函数声明的时候,会默认为返回int型。

比如,GetMaxFloat()函数,本来它应该是

float GetMaxFloat(float x, float y);

但编译器会当成是

int GetMaxFloat(double x, double y);

 

看看汇编:

正确的情况

先把12.3f和45.6f加载到s0和s1寄存器。调用GetMaxFloat函数得到计算结果,再保存到s19寄存器。

 

错误的情况

调用了__aeabi_f2d函数把a和b转换了一下(先变成double型?),再调用GetMaxFloat函数。

 

 

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值