预处理指令_宏定义

本文介绍了C语言中宏定义的应用,包括常量定义、多参数宏及多行宏定义等,并通过实例展示了宏定义与函数的区别。同时,还探讨了如何使用宏进行参数连接和实现可变参数的日志记录功能。

宏定义:

1.常量 单参数

2.变量多参数

多参数要注意加括号。

多参数换行需要加 \ 。

3.注意和函数的区别。

4.宏定义单纯的替换,不会检查类型,无返回值。



#include <stdio.h>
#include "time.h"
char *currentTime ()
{
    time_t rawtime;
    struct tm * timeinfo;
    time ( &rawtime );
    timeinfo = localtime ( &rawtime );
    //printf ( "\007The current date/time is: %s", asctime (timeinfo) );
    return asctime(timeinfo);
}

#define MAXNUM(A,B) A>B?A:B

//多行宏定义
#define LOOP(FROM,TO,CONTENT)\
    for(int index=FROM;index<TO;index++){\
    CONTENT;\
}

void snsslmmSayHi(){
    printf("HI\n");
}

void snsslmmSayHello(){
    printf("HELLO\n");
}

//参数连接(换名)
#define SS_NEWNAME(EXNAME) snsslmm##EXNAME()

//可变参数:级别示例
#define LOG(LEVEL,FORMAT,...) printf(LEVEL);printf(FORMAT,__VA_ARGS__)
#define LOG_E(FORMAT,...) LOG("ERROR:",FORMAT,__VA_ARGS__)
#define LOG_W(FORMAT,...) LOG("WARNING:",FORMAT,__VA_ARGS__)
#define LOG_I(FORMAT,...) LOG("INFO:",FORMAT,__VA_ARGS__)
#define LOG_D(FORMAT,...) LOG("DEBUG:",FORMAT,__VA_ARGS__)


int main(void) {
    
    
    printf("Max num is %f\n",MAXNUM(10.1,5.5));
    LOOP(0,3,printf("Current num is %d\n",index));
    
    SS_NEWNAME(SayHi);
    SS_NEWNAME(SayHello);
    
    LOG_D("[%s]\n",currentTime());
    
    return 0;
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值