std::fwrite
来自cppreference.com
在标头 <cstdio> 定义 | ||
std::size_t fwrite(constvoid* buffer, std::size_t size, std::size_t count, std::FILE* stream ); | ||
写 count 个来自给定数组 buffer 的对象到输出流 stream。如同将每个对象判读为 unsignedchar 的数组,并对每个对象调用 size 次 std::fputc 以将那些 unsignedchar 按顺序写入 stream 一般写入。该流的文件位置指示器前进写入的字节数。
若对象不可平凡复制(TriviallyCopyable) ,则行为未定义。
若出现错误,则文件位置指示器的结果值不确定。
目录 |
[编辑]参数
buffer | - | 指向数组中要被写入的首个对象的指针 |
size | - | 每个对象的大小 |
count | - | 要被写入的对象数 |
stream | - | 要写入的输出文件流 |
[编辑]返回值
成功写入的对象数,若错误发生则可能小于 count。
若 size 或 count 为零,则 fwrite
返回零并不进行其他行动。
[编辑]示例
运行此代码
#include <array>#include <cstdio>#include <vector> int main (){// 写缓冲区到文件if(std::FILE* f1 =std::fopen("file.bin", "wb")){std::array<int, 3> v ={42, -1, 7};// std::array 的底层存储为数组 std::fwrite(v.data(), sizeof v[0], v.size(), f1);std::fclose(f1);} // 读取同一数据并打印它到标准输出if(std::FILE* f2 =std::fopen("file.bin", "rb")){std::vector<int> rbuf(10);// std::vector 的底层存储亦为数组std::size_t sz =std::fread(rbuf.data(), sizeof rbuf[0], rbuf.size(), f2);std::fclose(f2);for(std::size_t n =0; n < sz;++n)std::printf("%d\n", rbuf[n]);}}
输出:
42 -1 7
[编辑]参阅
(C++11) | 打印有格式输出到 stdout、文件流或缓冲区 (函数) |
写字符串到文件流 (函数) | |
从文件读取 (函数) | |
fwrite 的 C 文档 |