单片机计算需要注意的问题

本文探讨了在单片机编程中计算时应注意的问题,包括强制类型转换对结果的影响,整型计算中先乘除的区别,以及尽量避免浮点数运算以减少计算误差。
摘要由CSDN通过智能技术生成

单片机计算需要注意的问题

1、关于强制转换

U16 uwValue;     

U32 result1;

U32 result2;

result1= (U32)uwValue * 800;

result2= (U32)(uwValue * 800)

使用C8051F392单片机在keil编译器中得到如下计算结果:

uwValue

500

1000

10000

result1

0x61A80

0xC3500

0x7A1200

Result2

0x1A80

0x3500

0x1200

特别注意是先转换再乘与先乘再转换二者的计算结果区别很大

2、关于整形计算

对于整形数之间的计算,先乘再除与先除再乘之间的差别是很大的,因为整形之间相除会把小数部分省略。

如下程序及结果:

intm,n,x,y,z;

m=x*y/z;

n=x*

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值