linux内核中64位除法函数dodiv,C语言在linux内核中do while(0)妙用之法

为什么说do while(0) 妙?由于它的确就是妙,并且在linux内核中实现是相当的妙,我们来看看内核中的相关代码:

#define db_error(fmt, ...) do { fprintf(stderr, "(error): "); fprintf(stderr, fmt, ##__VA_ARGS__); } while (0)这仅仅是个普通的调试信息的输出。有人便会觉得。你这不是多此一举吗?去掉do while(0)不一样也实现了吗?事实上不然,我们看看样例就清楚了,虽然非常easy:

int main(void)

{

while(0)

{

printf("hello world\n");

}

do

{

printf("hello world1\n");

}while(0);

return 0 ;

}这是一段简单到不能再简单的代码了。但还是要提一下。请看执行结果:

谁都知道第一个while(0)肯定是不会执行的,由于while()括号里的数值等于0。逻辑判定为假。即代码块中的hello world不会执行,可是do while(0)就不一样了,do while(0)即使条件不成立。也会拼了老命的去执行一次!

也就是说。为什么内核代码要这样来做,这是由于内核代码採用do{}while(0);这种结构能够保证不管在什么地方都能够正确的运行一次 ,这就是它用得最妙的地方,否则有时候调试程序的时候,单单的调试语句写了没打印事实上是非常正常的事情,不知道大家写代码的时候有没有遇到过。反正我是遇到过了。后来就是用这种一种方法定位到错误点,顺利改正。

Center

代码虽简单。可是用好用精熟练使用不一定什么时候都能想得到,越简单的东西,有时候,适用价值还是非常好的!

laugh.gif

分享下面我实现的调试输出程序,以后能够拿来当模版开发了:

#include

#include

//内核代码採用do{}while(0);这样的结构能够保证不管在什么地方都能够正确的执行一次

#define db_error(fmt, ...) do { fprintf(stderr, "(error): "); fprintf(stderr, fmt, ##__VA_ARGS__); } while (0)

#define db_msg(fmt, ...) do { fprintf(stdout, "(msg): "); fprintf(stdout, fmt, ##__VA_ARGS__); } while (0)

#define db_warn(fmt, ...) do { fprintf(stdout, "(warn): "); fprintf(stdout, fmt, ##__VA_ARGS__); } while (0)

#define db_debug(fmt, ...) do { fprintf(stdout, "(debug): "); fprintf(stdout, fmt, ##__VA_ARGS__); } while (0)

int main(void)

{

db_error("h\n");

db_warn("e\n");

db_debug("llo\n");

return 0 ;

}执行结果:

调试信息在前,非常快就能够知道在什么地方打印的语句,方便DEBUG!

迅速找到程序bug的定位!

Center

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值