fwrite
From cppreference.com
| ヘッダー <stdio.h> で定義 |
||
| (C99まで) | ||
| (C99以降) | ||
指定された配列bufferからcount個のオブジェクトを、出力ストリームstreamに書き込みます。オブジェクトは、各オブジェクトをunsigned charの配列として再解釈し、各オブジェクトに対してsize回fputcを呼び出すことで、これらの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 The fwrite function (p: TBD)
- C17標準 (ISO/IEC 9899:2018)
- 7.21.8.2 The fwrite function (p: TBD)
- C11標準 (ISO/IEC 9899:2011)
- 7.21.8.2 The fwrite function (p: 335-336)
- C99標準 (ISO/IEC 9899:1999)
- 7.19.8.2 The fwrite function (p: 301-302)
- C89/C90標準 (ISO/IEC 9899:1990)
- 4.9.8.2 The fwrite function
[編集] 関連項目
| (C99)(C11)(C11)(C11)(C11) |
stdout、ファイルストリーム、またはバッファに書式化された出力を書き出す (関数) |
| ファイルストリームに文字列を書き込む (関数) | |
| ファイルから読み込む (関数) | |
| C++ドキュメント (fwrite)
| |