c++中宏的使用

1 条件include
如下:
#ifndef MAIN_H_
#define  MAIN_H_
……
#endif


       上面在看到头文件时会看到,作用就是阻止这个头文件被多次include,多次include就会出现重复的定义情况所以需要在每个头文件中都使用这个定义。
       如果还不是很了解要怎样使用 可以看看 c的标准头文件 如fcntl.h
2 条件编译
如下
#ifdef _DEBUG  //  Debug模式
printf( " this debug info " );
#endif
如果没有定义_DEBUG宏的话 那么上面那一行是不会编译进去的 ,但是定义了_DEBUG后,上面那行就会编译进去,可以写个简单的程序测试:
#include  < stdio.h >
int  main()
{
#ifdef _DEBUG
    printf(
"hello world ");
#else
    printf(
"no debug");
#endif
    
return 0;
}

第一次使用 gcc -D_DEBUG main.c
第二次使用 gcc main.c
运行两次的结果看看。
3 定义为某个值
以便后面修改这个值时不用修改其它地方代码 只要修改这个宏的定义就可以了。如一个软件的多语言版本等。
如下
#include  < stdio.h >
#define  PRINT_STR "你好 DD"
int  main() {
    printf(PRINT_STR);
    
return 0;
}
编译时会把PRINT_STR代替成"你好 DD"。

以后想修改时就方便了,另外也可以定义为函数。
#include  < stdio.h >

#ifdef _DEBUG
#define  A(x) a(x)
#else
#define  A(x) b(x)
#endif

int  a( int  x)
{
    
return x+1;
}


int  b( int  x) {
    
return x+100;
}


int  main() {
    printf (
"A(10) value is %d",A(10));
    
return 0;
}

其实也可以定义成
#define  A a

但是,定义成A(x)后,只有A后面带一个(x)类型的,编译器才会执行替换比较安全,可以保证只替换函数而不替换变量。






第四个 可变参数宏
有些时候定义一个宏来代替某个函数,但是这个函数是可变参数的话,那就需要考虑办法了。可变参数宏要C99才支持,使用时请检查编译器是否支持该标准。
定义方法如下
#define  PRINT(...) printf(__VA_ARGS__)
#include 
< stdio.h >
int  main() {
    PRINT(
"%d %s %s",1,"吃饭了吗 smile MM:)"," ");
    
return 0;
}

第五个 宏组合
也就是## 和 #的用法。
## 是连接符号,连接两个宏,#是把名字代替成字符串。
如下
#define  s5(a) supper_ ## a
#include 
< stdio.h >
void  supper_printf( const   char *  p )
{
    printf(
"this is supper printf: %s ",a);
}


int  main()
{
     s5(printf)(
"hello owrld");
     
return 0;
}
#用法如下
#include  < stdio.h >
#define  s(p) #p
int  main() {
    printf(s(p)
" ");
    
return 0;
}
运行一下就知道了。
补充说明:
     宏定义不支持递归定义。即,宏定义如果在右边碰到宏名字或右边又含有一个宏,在右边的宏又包含对左边的宏的话将不会再递归展开。如下代码:
#define  new DEBUG_NEW
#define  DEBUG_NEW new(__FILE__, __LINE__)

/*************************************
*
*此时的new会被展开成new(__FILE__, __LINE__),而不会递归展开。
*
***************************************
*/
#define  Fn(X)  4*Fn(X)   // 此时代码中的Fn(X)只会被替换成4*Fn(X),而不会被递归展开

你可能感兴趣的:(C/C++)