关于宏的副作用_应该多使用inline函数,少使用宏

今天写 rtc 驱动, rtc 寄存器使用了 bcd 编码, 于是写了一个宏进行转换:

#define FROMBCD8(val)   (((val >> 4)  & 0xf) * 10 + (val & 0xf))

 

然后为了获取某个寄存器,比如小时, 是这么调用的:

tm->tm_hour     = FROMBCD8(micco_read(RTC_HOUR_REG));

 

但是, micco_read 的打印语句表明该函数被调用了两次!

 

仔细研究原来这是由于宏的副作用导致的!

宏扩展后变为:

tm->tm_hour     =  (((micco_read(RTC_HOUR_REG)>> 4)  & 0xf) * 10 + (micco_read(RTC_HOUR_REG)& 0xf))

 

这导致了低效(有时是错误)的代码!micco_read 可是使用低速 i2c 在访问寄存器!

 

修改为:

u8 val;

val = micco_read(RTC_HOUR_REG);

tm->tm_hour     = FROMBCD8(val);

 

即可!

 

该实例,表明宏的缺陷!正确的方法是应该使用 inline 函数, 少使用宏。

上面的宏改为:

static u8 inline frombcd8(u8 val)

{

        return ((val >> 4)  & 0xf) * 10 + (val & 0xf);

}

 

然后, 调用改为:

tm->tm_hour     = frombcd8 (micco_read(RTC_HOUR_REG));

也没有问题, 而且代码更加简洁。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值