宏定义__FILE__,__LINE__,__VA_ARGS__等介绍与应用

ANSIC标准定义中常见的预定义宏

LINE:在源代码中插入当前源代码行号;

FILE:在源代码中插入当前源代码路径及文件名;

DATE:在源代码中插入当前编译日期;

TIME:在源代码中插入当前编译时间(编译时间,而非运行时的时间);

STDC:当要求程序严格遵循ANSIC标准时,该标识符赋值为1;

__cplusplus:当编写C++程序时该标识符被定义;

VA_ARGS:可变参数宏,用__VA_ARGS__代表用(...)表示的形参。

预定义宏应用举例

预定义宏常用域打印调试信息,如下例中,以gd32f30x环境为例,打印出程序运行中的提示或问题:

cpp 复制代码
#include "gd32f30x.h"
#include <stdio.h>
#include "gd32f307c_eval.h"
#include "stdarg.h"

void uart_configuration(void);
int fputc(int ch, FILE *f);

#define ERROR_PRINT(PFORMAT,...)  error_print(__FILE__, __func__, __LINE__, PFORMAT, __VA_ARGS__)

void error_print(const char *file, const char *func, int line, const char *format,...)
{
    va_list vaargs;
    va_start(vaargs,format);
    printf("error occured in file:%s ,in function:%s ,on line: %d. ",file,func,line);
    vprintf(format,vaargs);
    return;
}

void uart_configuration(void)
{
    rcu_periph_clock_enable(RCU_GPIOA);
    rcu_periph_clock_enable(RCU_USART0);
    
    gpio_init(GPIOA, GPIO_MODE_AF_PP, GPIO_OSPEED_50MHZ, GPIO_PIN_9);
    gpio_init(GPIOA, GPIO_MODE_IN_FLOATING, GPIO_OSPEED_50MHZ, GPIO_PIN_10);
    
    usart_deinit(USART0);
    usart_baudrate_set(USART0, 115200U);
    usart_receive_config(USART0, USART_RECEIVE_ENABLE);
    usart_transmit_config(USART0, USART_TRANSMIT_ENABLE);
    usart_enable(USART0);
    
    ERROR_PRINT("%s","error:RCU_GPIOB not enable");
}

int main(void)
{
    uart_configuration(); 
    
    while(1) {}
}

/* retarget the C library printf function to the USART */
int fputc(int ch, FILE *f)
{
    usart_data_transmit(USART0, (uint8_t)ch);
    while(RESET == usart_flag_get(USART0, USART_FLAG_TBE));
    return ch;
}

程序输出结果:

相关推荐
cccyi74 分钟前
【C++ 脚手架】etcd 的介绍与使用
c++·服务发现·etcd·服务注册
liu****7 分钟前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
fengfuyao9857 分钟前
VC++基于服务器的点对点文件传输实例
服务器·开发语言·c++
爱吃程序猿的喵22 分钟前
南邮计科电工电子实验B《RLC串联谐振电路》实验报告
单片机·嵌入式硬件
独小乐23 分钟前
009.中断实践之实现按键测试|千篇笔记实现嵌入式全栈/裸机篇
linux·c语言·驱动开发·笔记·嵌入式硬件·arm
山甫aa25 分钟前
List 容器 -----C++的stl学习
开发语言·c++·学习
CoderCodingNo30 分钟前
【GESP】C++四、五级练习题 luogu-P1177 【模板】排序
数据结构·c++·算法
Proxy_ZZ032 分钟前
从零实现LDPC比特翻转译码器:C语言实战与底层逻辑解析
c语言·算法
XINVRY-FPGA35 分钟前
XC7VX690T-2FFG1157I Xilinx AMD Virtex-7 FPGA
arm开发·人工智能·嵌入式硬件·深度学习·fpga开发·硬件工程·fpga
森G42 分钟前
58、最佳实践与注意事项---------多线程、竟态条件和同步
c++·qt