vsprintf

可変長引数リストのデータを書式文字列に従って文字配列に書き込みます.

#include <stdio.h>
#include <stdarg.h>
int vsprintf(
    char * restrict s,
    const char * restrict format,
    va_list arg
);

vsprintf 関数は可変長引数リストのデータを format が指す書式文字列に従って,s が指す文字配列へ書き込みを行います.文字配列に書き込んだ文字列の後にはナル文字 (null_character) が書き込まれます.

vsprintf の呼び出し前には va_start マクロで引数 arg を初期化しておく必要があります.また,vsprintf は va_end マクロを呼び出しません.したがってユーザーが手動で va_end を呼び出す必要があります.

vsprintf の動作は可変長引数を arg に置き換えた sprintf と同じです.

注意!
vsprintf はバッファオーバーフロー (buffer over-flow) を発生させやすい関数の 1 つです.

引数

  • s: 文字配列 (ここに書き込まれる)
  • format: 書式文字列 (詳しくは printf書式文字列を参照してください)
  • arg: 変換するパラメータのリスト (可変長引数リスト)

戻り値

  • 成功した場合: 書き込んだ文字数 (終端ナル文字は含めない)
  • 失敗した場合: 負の値

C言語サンプルプログラム

vsprintf 関数を使用して可変長引数リストのデータを文字配列に書き込むサンプルプログラムを以下に示します.

/* header files */
#include <stdio.h>
#include <stdlib.h>
#include <stdarg.h>

/* macros */
#define N 256

/* functions */
int ToTSV(char *tsv, char *format, ...);

/* main */
int main(void) {
    char tsv[N] = {'\0'};

    ToTSV(tsv, "%s\t%s\t%d", "1950", "チャーリー・ブラウン", 4);
    printf("%s\n", tsv);

    return EXIT_SUCCESS;
}

/**
 * @brief タブ区切りにして文字配列tsvに格納する
 * @param[IN] tsv タブ区切りの文字列
 * @param[IN] format 書式文字列
 * @param[IN] ... 可変長引数
 * @return EXIT_SUCCESS
 */
int ToTSV(char *tsv, char *format, ...) {
    va_list arg;

    va_start(arg, format);
    vsprintf(tsv, format, arg);
    va_end(arg);

    return EXIT_SUCCESS;
}

実行例

サンプルプログラムの実行結果は以下のようになります.

1950    チャーリー・ブラウン    4

cプログラマの必読書

たくさんあるc言語関連の書籍の中でも特に役に立った本です.よかったら参考にしてみてください.

c実践プログラミング 第3版

c言語の実践的参考書.少々値段は張りますが初心者を脱しようとしている人は絶対に読むべきです.
文法だけでなく,コーディングスタイルやデバッグなど文字通り「実践的」なことが書かれているので非常にためになります. オライリーの本は,読みにくい本が多いのですが本書はとても読みやすくオススメです.


c言語ポインタ完全制覇 (標準プログラマーズライブラリ)

ポインタの解説書としては最高の書籍です.
この1冊でポインタを完全に理解することができます.全くの初学者が読むには敷居が高いですが,入門書を読み終えた後に読むと非常に有益です.