第8章 IO类

8.1 IO类

iostream                    istream, wistream从流中读取数据

ostream, wostream

iostream, wiostream读写流

fstream                      ifstream, wifstream从文件中读取数据

ofstream, wofstream

fstream, wfstream读写文件

sstream                      istringstream, wistringstream从string中读取数据

ostringstream, wostringstream

stringstream, wstringstream读写string

为了支持宽字符wchar_t,所有的类型和函数只要以w开始就行。例如:wcin、wcout、wifstream。

8.1.1 IO对象无拷贝或赋值

ofstream out1, out2;

out1=out2;//错误,不能赋值和拷贝

由于不能赋值拷贝,所以不能将形参和返回值设置为流类型,通常必须使用引用方式传递和返回流。而且读写IO对象会改变对象状态,所以不能是const。

8.1.2 流的状态

可以通过流对象的rdstate成员函数返回一个iostate类型的值,表征流的当前状态。

    1. badbit,流崩溃
    2. failbit,IO操作失败
    3. eofbit,文件尾
    4. goodbit,没有错误

使用setstate函数可以将一个iostate的状态值设置为流的状态,对于已经有错误的流,使用good函数仍返回false。

使用无参的clear函数复位所有错误标识,执行clear()后,调用good返回true.

可能用到的函数:eof、fail、bad、good

8.1.3 管理输出缓冲

Endl可以完成换行,并刷新缓冲区。

cout << unitbuf;        //所有输出操作都会立即刷新缓冲区

cout << nounitbuf;   //将缓冲区刷新任务交给系统

 

将输入流关联到输出流

使用tie函数可以讲一个输出流,关联到输入流,并返回原来关联的输出流。

cin.tie(&cout);

不带参数的tie函数返回输入流关联的输出流。

8.2 文件输入输出

fstream

fstream fstrm(filePath);

fstream fstrm;

fstrm.open(filePath, mode);

fstrm.is_open();//检验是否成功打开是个好习惯

fstrm.close();

当一个fstream对象离开作用域时,与之关联的文件自动关闭。

Mode

只读:in

只写:out

每次写操作前定位到文件尾部:app

打开文件后定位到文件尾部:ate

截断文件:trunc

二进制方式进行IO:binary

注意:

    1. 每次调用open,都需要重新制定文件模式,否则为默认默认。
    2. out打开文件,文件从开头截断,为保留文件中的内容,应该同时指定为app
    3. 设定trunc,必须设定out:ofstream::out | ofstream::trunc
    4. 设定app,不能有trunc

8.3 string流

<sstream>头文件中

sstream strm;//未绑定的stringstream对象

sstream strm(s);//保存string s的一个拷贝

strm.str();//返回strm保存的string拷贝

strm.str(s);//将s拷贝到strm中,返回void

istringstream

将string类型通过istringstream当做流进行处理。

ostringstream

将其他流写入到ostringstream流中,可以相当于向string添加字符。

时间: 2024-11-10 18:16:33

第8章 IO类的相关文章

C++ Primer学习总结 第8章 IO库

 第8章 IO库 1.    IO类继承关系: 2.    查询iostream流状态P280-281 V是一个int,当我们输入1, 'r',或Ctrl+z 时的输出分别如下: cin.clear()可以清楚所有的错误位,使good()返回true. 3.    fstream对文件的读写P284 初始创建读入和写出fstream对象之后,把fin和fout完全看成cin和cout处理即可,它们操作几乎没有区别. 4.    对同一个文件同时打开进行读写会出现不可预知的BUG. 对于文件的操作

Lua_第 20 章 IO库

第 20 章 IO库 I/O  库为文件操作提供两种模式.简单模式(simple  model)拥有一个当前输入文件和一个当前输出文件,并且提供针对这些文件相关的操作.完全模式(complete  model) 使用外部的文件句柄来实现.它以一种面对对象的形式,将所有的文件操作定义为文件句柄的方法.简单模式在做一些简单的文件操作时较为合适.在本书的前面部分我们一直都在使用它.但是在进行一些高级的文件操作的时候,简单模式就显得力不从心.例 如同时读取多个文件这样的操作,使用完全模式则较为合适.I/

第十五章 文件属性类的实现

                  第十五章    文件属性类的实现        根用户的权限也不能是无限大.必须考虑到保护用户的隐私!用户的文件内容.程序代码可设置为根用户也不能观看,只能是文件拥有者可以查看.修改.但根用户可以删除一切非根用户的文件.也可以查看用户的目录.所以,i_mode字符更改如下:      BU16 i_mode; // 描述文件的访问权限:文件的读.写.执行权限  // i_mode.15-13  ftype; 文件类型: 0-符号软连接文件, // 1-硬连接文

C++ Primer Plus 第六版 第16章 string类和标准模板库

1.string实际上是模板具体化basic_string<char> 的一个typedef,有默认参数,所以省略了初始化参数 2.size_type是一个依赖于实现的整形 string将string::npos定义为字符串的最大长度 3.string类的构造函数P656 4.对于c-风格字符串,3种输入方法:cin>>   cin.getline(),cin.get 对于string   ,2种输入方法:cin>>,getline(cin,string对象) 5.st

设计模式 - 装饰者模式(Decorator Pattern) Java的IO类 使用方法

装饰者模式(Decorator Pattern) Java的IO类 使用方法 本文地址: http://blog.csdn.net/caroline_wendy/article/details/26716823 装饰者模式(decorator pattern)参见: http://blog.csdn.net/caroline_wendy/article/details/26707033 Java的IO类使用装饰者模式进行扩展, 其中FilterInputStream类, 就是装饰者(decora

CPrimer Plus第12章 存储类、链接和内存管理随笔

被static修饰的属于内部链接,不可被外部程序文件所使用一般而言,全局变量(文件作用域变量)具有静态存储期,局部变量(代码块作用域变量)具有自动存储期寄存器变量不能使用地址运算符因为被static修饰的变量不会中途被释放,所以不能用static修饰函数的形参变量的定义放在所有函数定义的外部即创建了一个外部变量,若外部变量在其他文件中定义,则需见extern修饰全局变量只能用常量表达式来赋值:int i;    int j = 2*i;不被允许 ptd = (double *)malloc(n

C++的那些事:流与IO类

1.流的概念 "流"就是"流动",是物质从一处向另一处流动的过程,比如我们能感知到的水流.C++的流是指信息从外部输入设备(如键盘和磁盘)向计算机内部(即内存)输入和从内存向外部输出设备(如显示器和磁盘)输出的过程,这种输入输出过程被形象地比喻为"流". 为了实现信息的内外流动,C++系统定义了I/O类库,其中的每一个类都称作相应的流或流类,用以完成某一方面的功能.根据一个流类定义的对象也时常被称为流. 通常标准输入或标准输出设备显示器称为标准流

C++ primer plus读书笔记——第11章 使用类

第11章 使用类 1. 运算符重载是一种形式的C++多态. 2. 不要返回指向局部变量或临时对象的引用.函数执行完毕后,局部变量和临时对象将消失,引用将指向不存在的数据. 3. 运算符重载的格式如下: operatorop(argument-list); 可以使用函数表示法或运算符表示法来使用它. total = coding + fixing; total = coding.operator+(fixing); 4. 运算符重载的限制: 1)  重载后的运算符必须至少有一个操作数是用户定义的类

第17章 特殊类成员

//*******引进静态成员变量的作用就是声明一个属于类而不属于对象的全局变量.意味着它为该类的所有实例所共享, //也就是说当某个类的实例修改了该静态成员变量,其修改值为该类的其它所有实例所见. //在某个类A中声明一个static int number;初始化为0.这个number就能被所有A的实例共用. // 在A的构造函数里加上number++,在A的析构函数里加上number--. // 那么每生成一个A的实例,number就加一,每销毁一个A的实例,number就减一, // 这样