• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

C++文件操作(fstream)

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

  我们在编写程序的时候,最密不可分的就是对文件进行相应的操作,我们可以从文件中读取数据,可以将数据保存到文件,可以……        

        文件在进行读写操作之前要先打开,使用完毕要关闭。所谓打开文件,实际上是建立文件的各种有关信息,并使文件指针指向该文件,以便进行其它操作。关闭文件则断开指针与文件之间的联系,也就禁止再对该文件进行操作。 

        总而言之,言而总之,一言以蔽之,对文件的操作是非常重要的,下面我们就来介绍一下C++中是如何对文件进行操作的。


        在C++中,有一个stream这个类,所有的I/O都以这个“流”类为基础的,对文件的操作是通过stream的子类fstream(file stream)来实现的,所以,要用这种方式操作文件,就必须加入头文件fstream.h。


打开文件
  文件名
    注意路径名中的斜杠要双写,如:
    "D:\\MyFiles\\ReadMe.txt"
  文件打开方式选项:
    ios::in    = 0x01, //供读,文件不存在则创建(ifstream默认的打开方式)
    ios::out    = 0x02, //供写,文件不存在则创建,若文件已存在则清空原内容(ofstream默认的打开方式)
    ios::ate    = 0x04, //文件打开时,指针在文件最后。可改变指针的位置,常和in、out联合使用
    ios::app    = 0x08, //供写,文件不存在则创建,若文件已存在则在原文件内容后写入新的内容,指针位置总在最后
    ios::trunc   = 0x10, //在读写前先将文件长度截断为0(默认)
    ios::nocreate = 0x20, //文件不存在时产生错误,常和in或app联合使用
    ios::noreplace = 0x40, //文件存在时产生错误,常和out联合使用
    ios::binary  = 0x80  //二进制格式文件
  文件保护方式选择项:
    filebuf::openprot;   //默认的兼容共享方式
    filebuf::sh_none;    //独占,不共享
    filebuf::sh_read;    //读共享
    filebuf::sh_write;   //写共享
  打开文件的方法
    调用构造函数时指定文件名和打开模式
    ifstream f("d:\\12.txt",ios::nocreate);         //默认以 ios::in 的方式打开文件,文件不存在时操作失败
    ofstream f("d:\\12.txt");                //默认以 ios::out的方式打开文件
    fstream f("d:\\12.dat",ios::in|ios::out|ios::binary); //以读写方式打开二进制文件
    使用Open成员函数
    fstream f;
    f.open("d:\\12.txt",ios::out);             //利用同一对象对多个文件进行操作时要用到open函数


检查是否成功打开
  成功:
    if(f){...}       //对ifstream、ofstream对象可用,fstream对象不可用。
    if(f.good()){...}
  失败:
    if(!f){...}       // !运算符已经重载
    if(f.fail()){...}


读写操作
  使用<<,>>运算符
  只能进行文本文件的读写操作,用于二进制文件可能会产生错误。
  使用函数成员 get、put、read、write等
  经常和read配合使用的函数是gcount(),用来获得实际读取的字节数。
注意事项
          打开方式中必须指定ios::binary,否则读写会出错
          用read\write进行读写操作,而不能使用插入、提取运算符进行操作,否则会出错。
          使用eof()函数检测文件是否读结束,使用gcount()获得实际读取的字节数


关闭文件
  使用成员函数close,如:
  f.close(); 
  利用析构函数
  对象生命期结束时会检查文件是否关闭,对没有关闭的文件进行关闭操作。


随机读写
  通过移动文件读写指针,可在文件指定位置进行读写。
  seekg(绝对位置);      //绝对移动,    //输入流操作
  seekg(相对位置,参照位置);  //相对操作
  tellg();          //返回当前指针位置
  seekp(绝对位置);      //绝对移动,    //输出流操作
  seekp(相对位置,参照位置);  //相对操作   
  tellp();          //返回当前指针位置
  参照位置:
  ios::beg  = 0       //相对于文件头
  ios::cur  = 1       //相对于当前位置
  ios::end  = 2       //相对于文件尾


        基于以上,我们就可以对文件流进行封装了。新建一个AL_File类,对所有操作进行封装。

       稍微注意下字节问题(指ASCII字符(单字节)和Unicode字符(宽字节)。前者占一个字节,后者占两个字节)

  1. #define (UNICODE) || (_UNICODE)  
  2. typedef char NCHAR;  
  3. //file  
  4. #define NCHARfstream    std::wfstream  
  5. #define NCHARifstream   std::wifstream  
  6. #define NCHARfostream   std::wofstream  
  7. #else //UNICODE || _UNICODE  
  8.   
  9. typedef WCHAR NCHAR;  
  10.   
  11. //file  
  12. #define NCHARfstream    std::fstream  
  13. #define NCHARifstream   std::ifstream  
  14. #define NCHARfostream   std::ofstream  
  15.   
  16. #endif // ASCI || UTF-8  

  1. /** 
  2.   @file         AL_File.h  
  3.   @brief        AL_File File operations 
  4.   @author   arvin 
  5.   @version  1.0   2013/03/14 
  6.  */  
  7.   
  8. #ifndef CXX_AL_FILE_H  
  9. #define CXX_AL_FILE_H  
  10.   
  11. #include <fstream>  
  12.   
  13. typedef long AL_ERROR;  
  14.   
  15. class AL_File  
  16. {  
  17. public:  
  18.     enum FILE_REFERENCE_POS;  
  19.   
  20.     /** 
  21.     * Construction 
  22.     * 
  23.     * @param 
  24.     * @return 
  25.     */  
  26.     AL_File();  
  27.   
  28.     /** 
  29.     * Construction 
  30.     * 
  31.     * @param        <IN> const NCHAR* cpFilePath 
  32.     * @param        <IN> WORD wOpenModel 
  33.     static const WORD MODEL_IN          = std::ios::in;         // 0x01, for reading the file does not exist, create (ifstream Open default) 
  34.     static const WORD MODEL_OUT         = std::ios::out;        // 0x02, for writing, the file does not exist, to create, if the file already exists, clear the original content (ofstream default Open) 
  35.     static const WORD MODEL_ATE         = std::ios::ate;        // 0x04, when the file is opened, the pointer in the file last. Can change the position of the pointer, often used in combination and in, out 
  36.     static const WORD MODEL_APP         = std::ios::app;        // 0x08, for writing, the file does not exist, to create, to write new content after the original contents of the file if the file already exists, the total in the final pointer position 
  37.     static const WORD MODEL_TRUNC       = std::ios::trunc;      // 0x10, length of the file read and write before first truncated to 0 (default) 
  38.     static const WORD MODEL_NOCREATE    = std::ios::_Nocreate;  // 0x20, file does not exist error, often used in combination and in or app 
  39.     static const WORD MODEL_NOREPLACE   = std::ios::_Noreplace; // 0x40, file exists generates an error when used in combination, often and out 
  40.     static const WORD MODEL_BINARY      = std::ios::binary;     // 0x80, binary format file 
  41.     * @param        <IN> WORD wAccess 
  42.     static const WORD ACCESS_ORDINARY   = 0;                    // 0: ordinary files, open access 
  43.     static const WORD ACCESS_READONLY   = 1;                    // 1: read-only file 
  44.     static const WORD ACCESS_HIDDEN     = 2;                    // 2: hidden file 
  45.     static const WORD ACCESS_SYSTEM     = 4;                    // 4: System Files 
  46.     * @return 
  47.     * @note 
  48.     * @attention    The default way to open a file to open the binary file reading and writing 
  49.                     The default file ordinary files, open access 
  50.     */  
  51.     AL_File(const NCHAR* cpFilePath, WORD wOpenModel = MODEL_IN|MODEL_OUT|MODEL_BINARY, WORD wOpenAccess = ACCESS_ORDINARY);  
  52.   
  53.     /** 
  54.     * Destruction 
  55.     * 
  56.     * @param 
  57.     * @return 
  58.     */  
  59.     ~AL_File(VOID);  
  60.   
  61.     ///////////////////////////////////Open the file///////////////////////////////////////  
  62.     /** 
  63.     * Open (Open the file) 
  64.     * 
  65.     * @param        <IN> const NCHAR* cpFilePath 
  66.     * @param        <IN> WORD wOpenModel 
  67.                         static const WORD MODEL_IN          = std::ios::in;         // 0x01, for reading the file does not exist, create (ifstream Open default) 
  68.                         static const WORD MODEL_OUT         = std::ios::out;        // 0x02, for writing, the file does not exist, to create, if the file already exists, clear the original content (ofstream default Open) 
  69.                         static const WORD MODEL_ATE         = std::ios::ate;        // 0x04, when the file is opened, the pointer in the file last. Can change the position of the pointer, often used in combination and in, out 
  70.                         static const WORD MODEL_APP         = std::ios::app;        // 0x08, for writing, the file does not exist, to create, to write new content after the original contents of the file if the file already exists, the total in the final pointer position 
  71.                         static const WORD MODEL_TRUNC       = std::ios::trunc;      // 0x10, length of the file read and write before first truncated to 0 (default) 
  72.                         static const WORD MODEL_NOCREATE    = std::ios::_Nocreate;  // 0x20, file does not exist error, often used in combination and in or app 
  73.                         static const WORD MODEL_NOREPLACE   = std::ios::_Noreplace; // 0x40, file exists generates an error when used in combination, often and out 

  74. 鲜花

    握手

    雷人

    路过

    鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
初学者如何在Linux(Ubuntu)下搭建C/C++开发环境发布时间:2022-07-13
下一篇:
C#特性类的使用发布时间:2022-07-13
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap