C++实现文本与二进制文件读写操作的示例

 更新时间:2026年01月07日 10:11:23   作者:司徒轩宇  
在C++开发中,文件操作是必备技能之一,本文将全面解析C++文件读写的操作方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

在C++开发中,文件操作是必备技能之一。本文将全面解析C++文件读写的核心概念、操作方法和最佳实践,包含丰富的代码示例。

一、文件操作核心类

C++通过<fstream>头文件提供三种核心类:

类名功能描述继承关系
ofstream文件输出流(写操作)继承自ostream
ifstream文件输入流(读操作)继承自istream
fstream文件输入输出流(读写操作)继承自iostream

二、文本文件操作

1. 写入文本文件

#include <fstream>
#include <string>

int main() {
    // 创建输出流(默认覆盖模式)
    std::ofstream outFile("data.txt");
    
    if (!outFile) {
        std::cerr << "文件创建失败!" << std::endl;
        return 1;
    }
    
    // 写入不同类型数据
    outFile << "用户日志\n";
    outFile << "ID: " << 1001 << "\n";
    outFile << "余额: $" << 2450.75 << "\n";
    
    // 自动关闭文件(RAII)
    return 0;
}

2. 读取文本文件

#include <fstream>
#include <iostream>

int main() {
    std::ifstream inFile("data.txt");
    
    if (!inFile.is_open()) {
        std::cerr << "文件打开失败!" << std::endl;
        return 1;
    }
    
    // 逐行读取
    std::string line;
    while (std::getline(inFile, line)) {
        std::cout << line << std::endl;
    }
    
    // 重置读取位置
    inFile.clear();
    inFile.seekg(0);
    
    // 格式化读取
    int id;
    double balance;
    inFile.ignore(100, ':');  // 跳过"ID: "
    inFile >> id;
    inFile.ignore(100, '$'); // 跳过"余额: $"
    inFile >> balance;
    
    std::cout << "\n解析结果: ID=" << id 
              << ", 余额=" << balance << std::endl;
    
    return 0;
}

三、二进制文件操作

1. 写入二进制数据

#include <fstream>

struct UserData {
    int id;
    double balance;
    char name[32];
};

int main() {
    UserData user = {1001, 2450.75, "张三"};
    
    std::ofstream binFile("user.dat", std::ios::binary);
    binFile.write(reinterpret_cast<char*>(&user), sizeof(user));
    
    return 0;
}

2. 读取二进制数据

#include <fstream>
#include <iostream>

int main() {
    std::ifstream binFile("user.dat", std::ios::binary);
    
    if (!binFile) {
        std::cerr << "二进制文件打开失败!" << std::endl;
        return 1;
    }
    
    UserData user;
    binFile.read(reinterpret_cast<char*>(&user), sizeof(user));
    
    std::cout << "用户ID: " << user.id << "\n"
              << "姓名: " << user.name << "\n"
              << "余额: " << user.balance << std::endl;
    
    return 0;
}

四、文件打开模式详解

通过位或运算符组合多种模式:

模式标志描述
std::ios::in读模式(默认ifstream)
std::ios::out写模式(默认ofstream)
std::ios::app追加模式(不覆盖原有内容)
std::ios::ate打开后定位到文件末尾
std::ios::trunc清空文件(默认)
std::ios::binary二进制模式
// 示例:以追加模式写入文本
std::ofstream logFile("app.log", 
                     std::ios::out | std::ios::app);
                     
// 示例:读写二进制文件(不截断)
std::fstream dataFile("records.dat",
                     std::ios::binary |
                     std::ios::in | 
                     std::ios::out);

五、错误处理机制

健壮的文件操作必须包含错误处理:

std::fstream file("critical.dat");

// 检查文件状态
if (file.fail()) {
    std::cerr << "文件操作失败!" << std::endl;
}

// 详细错误诊断
if (!file) {
    if (file.bad()) {
        std::cerr << "不可恢复的错误" << std::endl;
    } else if (file.eof()) {
        std::cerr << "到达文件末尾" << std::endl;
    } else if (file.fail()) {
        std::cerr << "非致命错误(如格式错误)" << std::endl;
    }
}

六、最佳实践与性能优化

1. RAII管理资源

{
    std::ofstream tmpFile("temp.txt");
    // 文件在作用域结束时自动关闭
}

2. 高效文件复制

bool copyFile(const std::string& src, const std::string& dst) {
    std::ifstream in(src, std::ios::binary);
    std::ofstream out(dst, std::ios::binary);
    
    if (!in || !out) return false;
    
    const size_t BUFFER_SIZE = 4096;
    char buffer[BUFFER_SIZE];
    
    while (in.read(buffer, BUFFER_SIZE)) {
        out.write(buffer, BUFFER_SIZE);
    }
    out.write(buffer, in.gcount());  // 写入剩余字节
    
    return true;
}

3. C++17文件系统操作

#include <filesystem>
namespace fs = std::filesystem;

// 检查文件存在
if (fs::exists("data.txt")) {
    // 获取文件大小
    auto size = fs::file_size("data.txt");
    // 重命名文件
    fs::rename("old.txt", "new.txt");
}

七、应用案例:日志系统

class Logger {
public:
    Logger(const std::string& filename) 
        : logFile(filename, std::ios::app) {}
    
    ~Logger() { if (logFile) logFile.close(); }
    
    void log(const std::string& message) {
        if (!logFile) return;
        
        auto now = std::chrono::system_clock::now();
        auto time = std::chrono::system_clock::to_time_t(now);
        logFile << std::put_time(std::localtime(&time), "%F %T")
                << " | " << message << "\n";
    }
    
private:
    std::ofstream logFile;
};

// 使用示例
Logger logger("app.log");
logger.log("系统启动");
logger.log("用户登录: ID=1001");

到此这篇关于C++实现文本与二进制文件读写操作的示例的文章就介绍到这了,更多相关C++ 文本与二进制文件读写操作内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C/C++实现双路快速排序算法原理

    C/C++实现双路快速排序算法原理

    这篇文章主要为大家详细介绍了C/C++实现双路快速排序算法原理,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-05-05
  • c调用python调试方法

    c调用python调试方法

    在本文里我们给大家分享了C中调用python调试的方法和相关知识点,需要的朋友们参考下。
    2019-02-02
  • C语言实现三子棋游戏附注释

    C语言实现三子棋游戏附注释

    这篇文章主要为大家详细介绍了C语言实现三子棋游戏附注释,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-06-06
  • C++11右值引用和std::move语句实例解析(推荐)

    C++11右值引用和std::move语句实例解析(推荐)

    右值引用(及其支持的Move语意和完美转发)是C++0x将要加入的最重大语言特性之一。这篇文章主要介绍了C++11右值引用和std::move语句实例解析,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-03-03
  • C++实现LeetCode(72.编辑距离)

    C++实现LeetCode(72.编辑距离)

    这篇文章主要介绍了C++实现LeetCode(72.编辑距离),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • 一文带你搞懂C++中的流量控制

    一文带你搞懂C++中的流量控制

    限流可以认为服务降级的一种,限流就是限制系统的输入和输出流量已达到保护系统的目的,这篇文章小编就来带大家深入了解一下如何利用C++实现流量控制吧
    2023-10-10
  • C++有符号和无符号整数的位移操作过程

    C++有符号和无符号整数的位移操作过程

    C++中位移操作对有符号与无符号整数处理不同:无符号左移补0,右移也补0;有符号右移补符号位(算术移位),左移可能触发未定义行为,需注意类型转换与跨平台兼容性
    2025-09-09
  • C语言实现简单停车场管理系统

    C语言实现简单停车场管理系统

    这篇文章主要为大家详细介绍了C语言实现简单停车场管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-12-12
  • 详解C++右值引用

    详解C++右值引用

    很多初学者都感觉右值引用晦涩难懂,其实不然。右值引用只不过是一种新的 C++ 语法,真正理解起来有难度的是基于右值引用引申出的2种 C++ 编程技巧,分别为移动语义和完美转发。本节给读者讲解什么是右值引用以及它的基本用法。
    2021-06-06
  • C++一个数组赋值给另一个数组方式

    C++一个数组赋值给另一个数组方式

    文章介绍了三种在C++中将一个数组赋值给另一个数组的方法:使用循环逐个元素赋值、使用标准库函数std::copy或std::memcpy以及使用标准库容器,每种方法都有其适用的场景和注意事项
    2025-02-02

最新评论