Namespaces
Variants

std:: fread

From cppreference.net
< cpp ‎ | io ‎ | c
定义于头文件 <cstdio>
std:: size_t fread ( void * buffer, std:: size_t size, std:: size_t count, std:: FILE * stream ) ;

从给定的输入流 stream 中读取最多 count 个对象到数组 buffer 中,其过程类似于对每个对象调用 std::fgetc 函数 size 次,并将按获取顺序得到的结果存储到 buffer 的连续位置中——该缓冲区被重新解释为 unsigned char 类型的数组。流的文件位置指示器会按读取的字符数前进。

如果对象不是 TriviallyCopyable ,则行为未定义。

如果发生错误,流的文件位置指示符的结果值是不确定的。如果读取了部分元素,其值也是不确定的。

目录

参数

buffer - 指向待读取数组中首个对象的指针
size - 每个对象的字节大小
count - 待读取对象的数量
stream - 用于读取的输入文件流

返回值

成功读取的对象数量,可能少于 count ,如果发生错误或遇到文件结束条件。

如果 size count 为零, fread 将返回零且不执行任何其他操作。

fread 不会区分文件结束和错误,调用方必须使用 std::feof std::ferror 来确定发生了哪种情况。

示例

#include <cstddef>
#include <cstdio>
#include <fstream>
#include <iomanip>
#include <iostream>
#include <vector>
int main()
{
    // 准备文件
    std::ofstream("test.txt") << 1 << ' ' << 2 << '\n';
    std::FILE* f = std::fopen("test.txt", "r");
    std::vector<char> buf(4); // char 是可平凡复制的
    const std::size_t n = std::fread(&buf[0], sizeof buf[0], buf.size(), f);
    std::cout << "读取 " << n << " 个对象" << (n > 1 ? "s" : "") << ": "
              << std::hex << std::uppercase << std::setfill('0');
    for (char n : buf)
        std::cout << "0x" << std::setw(2) << static_cast<short>(n) << ' ';
    std::cout << '\n';
    std::vector<std::string> buf2; // string 不是可平凡复制的
//  这将导致未定义行为:
//  std::fread(&buf2[0], sizeof buf2[0], buf2.size(), f);
}

可能的输出:

读取 4 个对象: 0x31 0x20 0x32 0x0A

参见

stdin 、文件流或缓冲区读取格式化输入
(函数)
从文件流获取字符串
(函数)
写入文件
(函数)
C 文档 for fread