nRF52840上va_start()的省略号问题

时间:2018-08-16 09:50:42

标签: c ellipsis nrf52

我想使用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是空的。我在做什么错了?

1 个答案:

答案 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个字节的大字符串进行打印。