关于宏的副作用_应该多使用inline函数,少使用宏
2009-06-12 14:09
239 查看
今天写 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));
也没有问题, 而且代码更加简洁。
#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));
也没有问题, 而且代码更加简洁。
相关文章推荐
- 关于虚拟化一些思考——不应该盲目使用
- 关于一些UI的property应该使用retain、strong还是weak的问题
- DBA应该知道的一些关于SQL Server跟踪标记的使用
- 关于expdp和impdp 使用EXPDP和IMPDP时应该注意的事项
- 关于虚拟化一些思考——不应该盲目使用
- 关于使用listView应该注意的地方
- DBA应该知道的一些关于SQL Server跟踪标记的使用
- 关于虚拟化一些思考——不应该盲目使用
- 关于php的一篇文章《php 应该使用缓存和连接池》
- 解决关于iis 中使用 word COM+ 组件的问题 ,应该基本上 都是 权限授权的问题
- 【随笔★DataReader的疑惑】关于使用DataReader的一个很奇怪的问题,不应该用DataReader?
- 关于代码优化中inline函数的使用
- 关于在Linux mint(应该所有基于ubuntu的发行版都是这样子)jade安装使用问题
- 关于在Linux mint(应该所有基于ubuntu的发行版都是这样子)jade安装使用问题
- 关于php的一篇文章《php 应该使用缓存和连接池》
- 关于使用UniForm以其他控件为Parent时应该注意的问题
- Android关于 手机返回键和代码finish()方法退出activity他们有什么区别;当activity使用共享动画时应该调用哪个方法,结束activity
- 关于phpexcel使用的框架总应该注意的事项
- 关于inline函数的使用
- 关于在Linux mint(应该所有基于ubuntu的发行版都是这样子)jade安装使用问题