• 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
    ");	
    	}
    	
    	do
    	{
    		printf("hello world1
    ");
    	}while(0);
    	
    	return 0 ; 
    }
    这是一段简单到不能再简单的代码了。但还是要提一下。请看执行结果:

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

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



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

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

    #include <stdio.h>
    #include <stdarg.h>
    //内核代码採用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
    ");
    	db_warn("e
    ");
    	db_debug("llo
    ");
    	return 0 ;
    }
    执行结果:

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

    迅速找到程序bug的定位!



  • 相关阅读:
    转:将SQL Server的数据导出成文本
    Docker 安装zookeeper并实现挂载
    Java在指定路径上创建文件,所在文件夹不存在时,自行创建文件夹
    Linux 安装kafka管理界面 kafkaeagle
    Linux环境安装Elasticsearch 7.16.0及常见问题解决
    Docker安装及配置kafka
    Docker安装ElasticSearc并实现挂载
    Linux下安装kafka
    Oracle 数据库备份与还原(Centos 7)
    Linux 清空.out 文件 nohup.out
  • 原文地址:https://www.cnblogs.com/jhcelue/p/7300780.html
Copyright © 2020-2023  润新知