我想使用va_start从省略号中检索我的参数。
这是我的代码:
char str[256];
void nrf_log_flash(bool is_to_save, char * log, ...){
va_list args;
va_start(args, log);
int ret = vsprintf(str, log, args);
if(is_to_save){
sprintf(str, "%s : %s\n", nrf_cal_get_time_string(false), log);
//my_nrf_log_add(str, strlen(str));
}
NRF_LOG_INFO("%s", log);
NRF_LOG_INFO("%s", str);
NRF_LOG_INFO("%d", ret);
va_end(args);
}
这是我的电话:
nrf_log_flash(true, "button %d pressed, %u, %x, %c", 2, 3658, 0xca, 'a');
但是我的va_list是空的。我在做什么错了?
答案 0 :(得分:1)
行后
int ret = vsprintf(str, log, args);
您的str变量包含格式化的字符串(例如str是“按下了按钮2、3658,ca,a”。但是,您接下来的句子将覆盖此数据。当您调用sprintf时,并用'log覆盖str处的数据'变量,其格式为(“按下按钮%d,%u,%x,%c”)
if(is_to_save){
//THIS CODE OVERWRITE YOUR STR BUFFER
sprintf(str, "%s : %s\n", nrf_cal_get_time_string(false), log);
//my_nrf_log_add(str, strlen(str));
}
顺便说一句,建议使用snprint和vsnprintf以避免缓冲区溢出。由于格式包含'%s',因此可能会使用大于256个字节的大字符串进行打印。