Можем ли мы вызвать va_start () дважды без промежуточного вызова va_end ()? - PullRequest
0 голосов
/ 06 января 2020

Вот мой минимальный пример:

#include <stdio.h>
#include <stdarg.h>
#include <string.h>

void print_strings_and_lengths(int count, ...)
{
    va_list ap;

    /* Print strings */
    va_start(ap, count);
    for (int i = 0; i < count; i++) {
        char *s = va_arg(ap, char *);
        printf("%d - %s\n", i, s);
    }

    /* Print string lengths */
    va_start(ap, count); /* Is it okay to call va_start() again without calling va_end()? */
    for (int i = 0; i < count; i++) {
        char *s = va_arg(ap, char *);
        printf("%d - %zu\n", i, strlen(s));
    }
    va_end(ap);
}

int main()
{
    print_strings_and_lengths(3, "apple", "ball", "cat");
    return 0;
}

Этот код дважды вызывает va_start() в одном и том же списке переменных аргументов. Функция va_end() не вызывается между двумя вызовами. Правильно ли определен этот код или он вызывает неопределенное поведение?

1 Ответ

2 голосов
/ 06 января 2020

C11 7.16.1 / 1:

[...] Каждый вызов макросов va_start и va_copy должен совпадать с соответствующим вызовом макроса va_end в одна и та же функция.

Для обоих вызовов va_start нет соответствующих va_end, поэтому код вызывает неопределенное поведение, без диагностики c, так как приведенная выше цитата не является частью Constraint.

...