命名空间
变体
操作

std::fread

来自 cppreference.com
< 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 的连续位置中,buffer 被重新解释为一个 unsigned char 数组。流的文件位置指示器将根据读取的字符数向前移动。

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

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

内容

[编辑] 参数

buffer - 指向要读取的数组中的第一个对象的指针
size - 每个对象的字节大小
count - 要读取的对象数量
stream - 要从中读取的输入文件流

[编辑] 返回值

成功读取的对象数量,如果发生错误或文件结束情况,该数量可能小于 count

如果 sizecount 为零,则 fread 返回零,不执行其他操作。

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

[编辑] 示例

#include <cstddef>
#include <cstdio>
#include <fstream>
#include <iomanip>
#include <iostream>
#include <vector>
 
int main()
{
    // Prepare file
    std::ofstream("test.txt") << 1 << ' ' << 2 << '\n';
    std::FILE* f = std::fopen("test.txt", "r");
 
    std::vector<char> buf(4); // char is trivially copyable
    const std::size_t n = std::fread(&buf[0], sizeof buf[0], buf.size(), f);
 
    std::cout << "Read " << n << " object" << (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 is not trivially copyable
//  This would result in undefined behavior:
//  std::fread(&buf2[0], sizeof buf2[0], buf2.size(), f);
}

可能的输出

Read 4 objects: 0x31 0x20 0x32 0x0A

[编辑] 另请参阅

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