C言語関数:fread





C言語のページでは、次の内容を解説しております。
C言語の入門講座  C言語の文法を中心に、基本的な関数などの解説をしています。
C言語ケーススタディ  C言語での実践的なプログラミングについて解説をしています。
C言語の関数リファレンス  C言語で用意されている関数を解説しています。
C言語で3次元動画プログラム  C言語で3次元タートルグラフィックを使用した3次元の動画プログラムの作成例です。
C言語の検定試験  C言語の文法に関する検定試験を実施することができます。
C言語でゲーム作成  C言語を使用したゲームの作り方を解説したページも用意しております。



2014年10月より個人の方を対象に、Study C無料提供を開始しました。
C言語を勉強中の方は、学習・教育に最適なC言語インタープリタのStudy Cを使ってみてください(個人の方は無料です)。
大学・高専・高校などの教育機関での採用実績も多数あるロングセラー商品Study Cが、個人向けに無料提供を始めました。
インタープリタの手軽さに加え、ゲームや3Dタートルグラフィックで楽しく勉強したりと、C言語の学習を協力にサポートします。
ブロック崩しゲーム 3Dツリー クリスマスツリー
また、このようなボタンの用意されているページでは、掲載しているプログラムをStudy Cに直接ロードし実行したりすることができます。
Study Cにロードする Study Cにロードし編集する Study Cにロードし実行する
Study C無料利用についての詳細は、このページを参照してください。




■fread
streamからのデータ読み込み

【分類】
標準入出力/ストリーム関数

【書式】
unsigned fread(void *ptr, unsigned size, unsigned nobj, FILE *stream);

【パラメータの型と説明】

パラメータ説明
void *ptr読み込み用バッファ(メモリ)のアドレス
unsigned size1つのデータの大きさ
unsigned nobj入力するデータの数
FILE *streamファイルポインタ(ストリーム)

【機能説明】
streamで指定したストリームからsizeバイトの大きさのデータをnobj個読み込み、ptrの指すメモリに格納します。
返り値として読み込んだデータの数を返します(読み込んだバイト数ではありません)。
読み込みの途中でファイルの終わりに達したときは、nobjよりも小さい値を返します。

fread()関数の使用例です。 「test.txt」というファイルの内容を読み込むプログラムです。 実行する前に、ファイルを作成しておく必要があります。 次のコマンドでファイルを作成してください。

C:\StudyC\MyProg>echo test file>test.txt

C:\StudyC\MyProg>type test.txt
test file

これで読み書き可能な(普通の状態)ファイル「test.txt」が作成されました。
※echoコマンドは画面に文字列を表示するものです。 他の多くのコマンドでも同じですが、最後に「>ファイル名」を指定すると画面に表示される内容がファイルに書き込まれます。

#include <stdio.h>

main()
{
        FILE    *fp;
        char    buff[100+1];
        int     rc;

        fp = fopen("test.txt", "r");
        if (fp == NULL)
        {
                printf("ファイルオープンエラー\n");
                return;
        }
        rc = fread(buff, 1, 100, fp);
        if (rc == 0)
        {
                printf("読み込みデータなし\n");
        }
        else
        {
                buff[rc] = '\0';
                printf("fread:%d - %s\n", rc, buff);
        }
        rc = fread(buff, 1, 100, fp);
        if (rc == 0)
        {
                printf("読み込みデータなし\n");
        }
        else
        {
                buff[rc] = '\0';
                printf("fread:%d - %s\n", rc, buff);
        }
        fclose(fp);
}

実行結果は以下になります。

fread:10 - test line

1.fopen()関数で「test.txt」ファイルをオープンします。
「ファイルオープンエラー」と表示される場合は、事前にファイルが作成できていない可能性があるので確認してください。
2.fread()関数でファイル「test.txt」の内容を読み込みます(1バイト×100個)。
fread()関数の読み込み指定方法は、少し変わっています。 「2番目のパラメータ×3番目のパラメータ」のサイズの領域に読み込みます。
この例では2番目のパラメータに1を指定しています。このため読み込んだ個数がバイト数に相当しています。
3.printf()関数で読み込んだ内容を表示します。
4.再度fread()関数で読み込もうとしますが、ファイルの最後に到達しているので0が返されます。
実は1回目の呼び出し結果が10なので最大の読み込み可能な個数100を下回っています。このためこの時点で次に読み込むべきデータが無いことを示しています。

「buff[rc] = '\0';」でfread()関数で読み込んだ配列の最後に'\0'を書き込む必要があります。 文字列の最後には'\0'が必要なためです。
これを行わないとprintf()関数などで文字列として表示できません。
また、配列のサイズが「100+1」なのはfread()関数が最大のサイズ(100バイト)で読み込んだときに'\0'を書き込む位置が必要なためです。

※このプログラムは、ファイルの内容がテキストと仮定しています。

【参照関数】
fwrite