Namespaces
Variants

fwrite

From cppreference.net
< c ‎ | io
ヘッダーで定義 <stdio.h>
size_t fwrite ( const void * buffer, size_t size, size_t count,
FILE * stream ) ;
(C99まで)
size_t fwrite ( const void * restrict buffer, size_t size, size_t count,
FILE * restrict stream ) ;
(C99以降)

指定された配列 buffer から count 個のオブジェクトを出力ストリーム stream に書き込みます。各オブジェクトは unsigned char の配列として再解釈され、 fputc が各オブジェクトに対して size 回呼び出されることで、これらの unsigned char が順番に stream に書き込まれます。ストリームのファイル位置指示子は、書き込まれた文字数分だけ進められます。

エラーが発生した場合、ストリームのファイル位置指示子の結果の値は不定となります。

目次

パラメータ

buffer - 書き込む配列の最初のオブジェクトへのポインタ
size - 各オブジェクトのサイズ
count - 書き込むオブジェクトの数
stream - 出力ストリームへのポインタ

戻り値

正常に書き込まれたオブジェクトの数。エラーが発生した場合、 count より少なくなる可能性があります。

size または count がゼロの場合、 fwrite はゼロを返し、それ以外の処理は実行しません。

#include <assert.h>
#include <stdio.h>
#include <stdlib.h>
enum { SIZE = 5 };
int main(void)
{
    double a[SIZE] = {1, 2, 3, 4, 5};
    FILE* f1 = fopen("file.bin", "wb");
    assert(f1);
    size_t r1 = fwrite(a, sizeof a[0], SIZE, f1);
    printf("wrote %zu elements out of %d requested\n", r1, SIZE);
    fclose(f1);
    double b[SIZE];
    FILE* f2 = fopen("file.bin", "rb");
    size_t r2 = fread(b, sizeof b[0], SIZE, f2);
    fclose(f2);
    printf("read back: ");
    for (size_t i = 0; i < r2; ++i)
        printf("%0.2f ", b[i]);
}

出力:

wrote 5 elements out of 5 requested
read back: 1.00 2.00 3.00 4.00 5.00

参考文献

  • C23規格 (ISO/IEC 9899:2024):
  • 7.21.8.2 fwrite関数 (p: TBD)
  • C17規格 (ISO/IEC 9899:2018):
  • 7.21.8.2 fwrite関数 (p: 未定)
  • C11規格 (ISO/IEC 9899:2011):
  • 7.21.8.2 fwrite関数 (p: 335-336)
  • C99規格 (ISO/IEC 9899:1999):
  • 7.19.8.2 fwrite関数 (p: 301-302)
  • C89/C90標準 (ISO/IEC 9899:1990):
  • 4.9.8.2 fwrite関数

関連項目

書式付き出力を stdout 、ファイルストリーム、またはバッファに出力する
(関数)
文字列をファイルストリームに書き込む
(関数)
ファイルから読み込む
(関数)