std:: fread
| I/O manipulators | ||||
| Print functions (C++23) | ||||
| C-style I/O | ||||
| Buffers | ||||
|
(C++23)
|
||||
|
(
C++98/26*
)
|
||||
|
(C++20)
|
||||
| Streams | ||||
| Abstractions | ||||
| File I/O | ||||
| String I/O | ||||
| Array I/O | ||||
|
(C++23)
|
||||
|
(C++23)
|
||||
|
(C++23)
|
||||
|
(
C++98/26*
)
|
||||
|
(
C++98/26*
)
|
||||
|
(
C++98/26*
)
|
||||
| Synchronized Output | ||||
|
(C++20)
|
||||
| Types | ||||
| Error category interface | ||||
|
(C++11)
|
||||
|
(C++11)
|
| Types and objects | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Functions | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
定义于头文件
<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
|
|