fwrite
|
ヘッダーで定義
<stdio.h>
|
||
| (C99まで) | ||
| (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関数
関連項目
|
(C99)
(C11)
(C11)
(C11)
(C11)
|
書式付き出力を
stdout
、ファイルストリーム、またはバッファに出力する
(関数) |
|
文字列をファイルストリームに書き込む
(関数) |
|
|
ファイルから読み込む
(関数) |
|
|
C++ documentation
for
fwrite
|
|