#include <stdio.h>
#include <stdint.h>
/**
* @brief Get the first argument
*
* @param ... Arguments to select
*
* @return First argument or empty if no arguments are provided
*/
#define GET_VA_ARG_1(...) GET_VA_ARG_1_(__VA_ARGS__, ) // Make sure that also for 1 argument it works
#define GET_VA_ARG_1_(a1, ...) a1
/**
* @brief Get all the arguments but the first one
*
* @param ... Arguments to select
*
* @return All arguments after the first one or empty if less than 2 arguments are provided
*/
#define GET_ARGS_AFTER_1(...) GET_ARGS_AFTER_1_(__VA_ARGS__, ) // Make sure that also for 1 argument it works
#define GET_ARGS_AFTER_1_(a1, ...) __VA_ARGS__
#define NRF_LOG_INTERNAL_INIT(...) \
nrf_log_init(GET_VA_ARG_1(__VA_ARGS__), \
GET_VA_ARG_1(GET_ARGS_AFTER_1(__VA_ARGS__, LOG_TIMESTAMP_DEFAULT_FREQUENCY)))
#define NRF_LOG_INIT(...) NRF_LOG_INTERNAL_INIT(__VA_ARGS__)
int main()
{
printf( GET_VA_ARG_1("123","456","789") );
printf("\r\n");
printf( GET_VA_ARG_1(GET_ARGS_AFTER_1("abc","def","hij")) );
printf("\r\n");
return 0;
}
这个宏提供两个参数,第一个函数是时间戳函数,第二个参数是时间戳频率,如果没有提供,则使用默认频率
NRF_LOG_TIMESTAMP_DEFAULT_FREQUENCY ,如果使能NRF_LOG_STR_FORMATTER_TIMESTAMP_FORMAT_ENABLED,
则频率用于格式化时间戳前缀。
__VA_ARGS__:总体来说就是将左边宏中 ... 的内容原样抄写在右边 __VA_ARGS__ 所在的位置。它是一个可变参数的宏,是新的C99规范中新增的,目前似乎只有gcc支持(VC从VC2005开始支持)