va_list | Programming Place Plus C言語編 標準ライブラリのリファレンス

トップページC言語編標準ライブラリのリファレンス(名前順)

トップページC言語編標準ライブラリのリファレンス(ヘッダ別)


va_list

概要

可変個の実引数を扱うための情報を保持するための型。

ヘッダ

stdarg.h

形式

typedef void* va_list;

詳細

可変個引数を処理する各種マクロ(va_***)が使用する型。形式は環境によって異なる。

注意

va_list型のオブジェクトを、可変個引数を持つ関数から別の関数へ引き渡しても構わないが、引き渡し先の関数内で va_argマクロを使用した場合、元の関数での va_list型のオブジェクトの値は不定になる。va_endマクロで一連の処理を終わらせ、va_startマクロを呼びなおす必要がある。

使用例

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

void print(const char* format, ...);

int main(void)
{
    print("ddcd", 10, 20, 'x', 30);
    print("ss", "abc", "def");
    print("dfc", 50, 3.3, 'Z');
}

/*
    標準出力へ任意の個数・型の値を出力する
    引数:
        format:     変換指定子を並べたもの。以下のいずれかとする。
                        d … 符号付き整数型
                        f … 実浮動小数点型
                        c … 文字型
                        s … 文字列型
                    とする。
                    たとえば、"dds" と指定すると、
                    後続の実引数が 整数型, 整数型, 文字列型 の順番で並んでいるものと判断される。
        ...:        出力する値のリスト
*/
void print(const char* format, ...)
{
    va_list args;
    va_start(args, format);

    for (const char* p = format; *p != '\0'; ++p) {
        switch (*p) {
        case 'd':
            printf("%d ", va_arg(args, int));
            break;
        case 'f':
            printf("%lf ", va_arg(args, double));
            break;
        case 'c':
            printf("%c ", va_arg(args, char));
            break;
        case 's':
            printf("%s ", va_arg(args, const char*));
            break;
        default:
            assert(!"不正な変換指定");
            break;
        }
    }
    printf("\n");

    va_end(args);
}

実行結果

10 20 x 30
abc def
50 3.300000 Z

関連

可変個実引数の値を取得するために va_argマクロを使う。可変個実引数を取得する操作を始めるにあたっては va_startマクロを、終える際に va_endマクロを用いる。

解説章

第52章


参考リンク


更新履歴

’2018/4/19 全体的に文章を見直し修正。「注意」「関連」を追加。

’2018/1/22 新規作成。



標準ライブラリのリファレンス(名前順)のトップページへ

標準ライブラリのリファレンス(ヘッダ別)のトップページへ

C言語編のトップページへ

Programming Place Plus のトップページへ



はてなブックマーク に保存 Pocket に保存 Facebook でシェア
X で ポストフォロー LINE で送る noteで書く
rss1.0 取得ボタン RSS 管理者情報 プライバシーポリシー
先頭へ戻る