1、定义复杂的宏以避免错误
do{...}while(0)在C中是唯一的构造程序,让你定义的宏总是以相同的方式工作,这样不管怎么使用宏(尤其在没有用大括号包围调用宏的语句),宏后面的分号也是相同的效果。


示例
#define foo(x) bar(x); baz(x)
foo(wolf);等价于bar(wolf); baz(wolf);
if(condition)foo(wolf);等价于 if (condition) bar(wolf); baz(wolf);


#define foo(x) do{bar(x); baz(x);}while(0)
if(condition)foo(wolf);等价于if(condition) do{bar(x); baz(x);}while(0);

2、避免使用goto控制程序流
在一些函数中,我们在return语句之前可能需要做一些工作,比如释放在函数一开始由malloc函数申请的内存空间,使用goto总是一种简单的方法:

int foo() 
{ 
    somestruct* ptr = malloc(...); 
    dosomething...; 
    if(error) 
    { 
        goto END; 
    } 
    dosomething...; 
    if(error) 
    { 
        goto END; 
    } 
    dosomething...;  
    END: 
    free(ptr); 
    return 0;   
}

但由于goto关键字可能会使代码不易读,因此许多人都不推荐使用它,那么我们可以使用do{...}while(0)来解决这一问题:

int foo() 
{ 
    somestruct* ptr = malloc(...); 
    do{ 
        dosomething...; 
        if(error) 
        { 
            break; 
        }
        dosomething...; 
        if(error) 
        { 
            break; 
        } 
        dosomething...; 
    }while(0); 
    free(ptr); 
    return 0;   
}

这里,我们使用do{...}while(0)来包含函数的主要部分,同时使用break替换goto,代码的可读性增强了。

3、避免由宏引起的警告
由于内核不同体系结构的限制,我们可能需要多次使用空宏。在编译的时候,这些空宏会产生警告,为了避免这种警告,我们可以使用do{...}while(0)来定义空宏:

#define EMPTYMICRO do{}while(0)

这样在编译的时候就不会产生警告。

4、定义单一的函数块来完成复杂的操作
如果你有一个复杂的函数且你不想要创建新的函数,那么使用do{...}while(0),你可以将一些代码放在这里面并定义一些变量,这样你就不必担心do{...}while(0)外面的变量名是否与do{...}while(0)里面的变量名相同造成重复了。

【参考文献】
1、http://www.cnblogs.com/lanxuezaipiao/p/3535674.html
2、http://www.cnblogs.com/lanxuezaipiao/p/3535626.html