vfprintf,vfwprintf
stdio.h:インデックス への移動
ヘッダーファイル
stdio.h
カテゴリ
入出力ルーチン
プロトタイプ
int vfprintf(FILE *stream, const char *format, va_list arglist);
int vfwprintf(FILE *stream, const wchar_t *format, va_list arglist);
説明
ストリームに書式付き出力を書き込みます。
v...printf 系関数は,...printf 系関数のかわりに使用できます。これらの関数の機能は,対応する ...printf 系関数とまったく同じですが,引数リストではなく引数リストへのポインタを受け取る点が異なります。
書式指定子の詳細は,「Printf の書式指定子」を参照してください。
vfprintf は,一連の引数を指すポインタを受け取り,format が指す書式文字列に含まれる書式指定子を各引数に適用し,書式付きデータをストリームに出力します。argument と同じ数の書式指定子がなければなりません。
戻り値
成功した場合,vfprintf は,出力されたバイト数を返します。
エラーが発生した場合は,EOF を返します。
例
#include <stdio.h>
#include <stdlib.h>
#include <stdarg.h>
FILE *fp;
int vfpf(char *fmt, ...)
{
va_list argptr;
int cnt;
va_start(argptr, fmt);
cnt = vfprintf(fp, fmt, argptr);
va_end(argptr);
return(cnt);
}
int main(void)
{
int inumber = 30;
float fnumber = 90.0;
char string[4] = "abc";
fp = tmpfile();
if (fp == NULL)
{
perror("tmpfile() call");
exit(1);
}
vfpf("%d %f %s", inumber, fnumber, string);
rewind(fp);
fscanf(fp,"%d %f %s", &inumber, &fnumber, string);
printf("%d %f %s\n", inumber, fnumber, string);
fclose(fp);
return 0;
}
移植性
POSIX | Win32 | ANSI C | ANSI C++ | |
---|---|---|---|---|
vfprintf |
+ |
+ |
+ |
+ |
vfwprintf |
+ |
+ |
+ |