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

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

先頭へ戻る

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.3f, 'Z' );

    return 0;
}

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

    va_start( args, format );

    for( p = format; *p != '\0'; ++p ){
        switch( *p ){
        case 'd':
            printf( "%d ", va_arg(args, int) );
            break;
        case 'f':
            printf( "%f ", 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 に保存 Twitter でツイート Twitter をフォロー
Facebook でシェア Google+ で共有 LINE で送る rss1.0 取得ボタン RSS