IO库的组成

三种流

C++的IO库以流对象为实体。主要有三种流:

(1)标准输入输出流

(2)文件输入输出流

(3)字符串输入输出流

流迭代器

输入输出流迭代器

instream_iterator<type>

ostream_iterator<type>

从控制台到容器

istream_iterator<T> first(cin);

istream_iterator<T> last;

copy(first,last,back_inserter(v));//调用容器的push_back方法

vector<string> vs(first,last);

从容器到控制台

ostream_iterator<T> first(cout," ");

copy(v.begin(),v.end(),first);

从文件到容器

ifstream fin("inputfile.txt");

istream_iterator<T> first(fin),last;

vector<T> v(first,last);

从文件到string

ifstream fin("inputfile.txt");

//以下再读取字符的时候文件里的空白字符也会放到string中

istreambuf_iterator<char> first(fin),last;//注意与上面一段的差别

string v(first,last);

//假设使用istream_iterator<char> first(fin),last;则会从文件里用

//>>操作符读取char变量放到string中,空白符丢失

从容器到文件

ofstream fout("outputfile.txt");

ostream_iterator<T> first(fout," ");//注意这里不须要last

copy(v.begin(),v.end(),first);

流对象的状态

s.eof()        //流结束状态,输入流中已经读全然部数据。再读一次就会是eof为true

s.fail()        //变量转换失败clear(ios::failbit)

s.bad()         //

s.clear()       //全部状态重置为有效

容器都有自己的迭代器

容器

vector 

string 

deque 

list

v.begin()      v.end()

l.cbegin()    l.cend()

流的迭代器

流迭代器用来写入流,或者从读流对象读数据,输入流迭代器使用strm>>t操作,将数据写到变量中。你看看>>操作符像不像箭头,这个箭头代表了数据的流向,C++作者说的。呵呵。

相同输出流使用<<操作符,将变量的数据写到流中。

输入流迭代器                                                                                     输出流迭代器

istream_iterator<T> iter_begin(strm),iter_end;                          ostream_iterator<T> iter_begin(strm),iter_end;/

以变量为单位。空白符将会被吃掉                                        以变量为单位,空白符将会被吃掉

istreambuf_iterator<char> iter_begin(strm),iter_end;           ostreambuf_iterator<char> iter_begin(strm),iter_end;

以字符为单位,空白符将会依照一个单位处理                以字符为单位,空白符将会依照一个单位处理

字符流迭代器演示样例

#include <iostream>
#include <string>
#include <sstream>
#include <iterator>
#include <algorithm>
using namespace std; int main(int , char**)
{
std::string str("a b c 123 !");
cout<<str<<endl; stringstream ss(str);
istreambuf_iterator<char> itrBegin(ss),itrEnd;
copy(itrBegin, itrEnd, ostream_iterator<char>(cout)); return 0; }

C++打印main.cpp源码

#include <iostream>
#include <fstream>
#include <algorithm>
#include <iterator>
using namespace std; int main(int argv, char** argc)
{
ifstream fin("main.cpp");
//buf迭代器会得到空白字符
istreambuf_iterator<char> itrFile(fin), endFile;
//输出迭代器只迭代一个char就可以,不须要是buf迭代器
ostream_iterator<char> itrCout(cout);
copy(itrFile, endFile, itrCout);
return 0;
}

C++打印main.cpp源码

(先放到字符串中,再打印字符串)

#include <iostream>
#include <fstream>
#include <algorithm>
#include <iterator>
using namespace std; int main(int argv, char** argc)
{
ifstream fin("main.cpp");
string str;
istreambuf_iterator<char> itrFileBegin(fin), itrFileEnd;
copy(itrFileBegin, itrFileEnd, back_inserter(str));//把源文件内的代码(包含字符和空格)放到字符串中
//仅仅有遇到'\0'才会结束,而源文件里的空格字符(' '相应的数值为32)
//,回车字符,Tab字符相应的值都不是'\0',所以都能被打印出来
cout<<str.c_str()<<endl;
return 0;
}




数据的流动

copy(iter_from_begin,iter_from_end,iter_dest_begin);

<iterator>                                                                                            <iterator>

inserter(strm)             //v.insert                                             istream_iterator<T> iter_begin(strm),iter_end;

back_inserter(strm)  //v.push_back                                  istreambuf_iterator<char> iter_begin(strm),iter_end;

front_inserter(strm)  //v.push_front

<------------------------------------------------------        数据             < ---------------------------------------------------

容器                                                                                                                                                                               流对象

vector                                                                                                                                                                                    fstream

string                                                                                                                                                                           sstream

list     deque                                                                                                                                                                        cin  cout

---------------------------------------------------------->         数据           ---------------------------------------------------->

v.begin()      v.end()                                          ostream_iterator<T> iter_begin(strm),iter_end;/

l.cbegin()    l.cend()                                         ostreambuf_iterator<char> iter_begin(strm),iter_end;

copy(iter_from_begin,iter_from_end,iter_dest_begin);

演示样例:

#include <iostream>
#include <sstream>
#include <string>
#include <vector>
#include <algorithm>
#include <iterator>
using namespace std; int main(int argc, char *argv[])
{
int temp_int[5] = {1,2,3,4,5};
vector<int> vector_int;
//array to vector
copy(temp_int,temp_int+sizeof(temp_int)/sizeof(int),back_inserter(vector_int));
//vector to cout
copy(vector_int.begin(),vector_int.end(),ostream_iterator<int>(cout," "));
cout<<endl;
//vector to stringstream
stringstream strm;
copy(vector_int.begin(),vector_int.end(),ostream_iterator<int>(strm," "));
cout<<strm.str()<<endl;
//stringstream to vector<string>
vector<string> vector_string;
copy(istream_iterator<string>(strm),istream_iterator<string>(),back_inserter(vector_string));
copy(vector_string.begin(),vector_string.end(),ostream_iterator<string>(cout," "));
cout<<endl; return 0;
}

输出例如以下:

1 2 3 4 5

1 2 3 4 5

1 2 3 4 5

请按随意键继续. . .

标准C++ I/O库 迭代器让数据自由流动 V8的更多相关文章

  1. c/c++ 标准库 迭代器(iterator)

    c/c++ 标准库 迭代器 begin和end运算符返回的具体类型由对象是否是常量决定,如果对象是常量,begin和end返回const_iterator:如果对象不是常量,返回iteraotor 1 ...

  2. WebGIS中基于控制点库进行SHP数据坐标转换的一种查询优化策略

    文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1.前言 目前项目中基于控制点库进行SHP数据的坐标转换,流程大致为:遍 ...

  3. Libscore – 收集 JavaScript 库的使用数据

    Libscore 扫描网络上成千上万的网站,收集统计 JavaScript 库的使用数据.在搜索框中,输入关键词,例如 jQuery, Modernizr, $.ui 或者 $.fn.fancybox ...

  4. SQL Server跨库复制表数据错误的解决办法

    SQL Server跨库复制表数据的解决办法   跨库复制表数据,有很多种方法,最常见的是写程序来批量导入数据了,但是这种方法并不是最优方法,今天就用到了一个很犀利的方法,可以完美在 Sql Serv ...

  5. 项目中通过Sorlj获取索引库中的数据

    在开发项目中通过使用Solr所提供的Solrj(java客户端)获取索引库中的数据,这才是真正对项目起实质性作用的功能,提升平台的检索性能及检索结果的精确性 第一步,引入相关依赖的jar包 第二步,根 ...

  6. [转]使用 Angular CLI 和 ng-packagr 构建一个标准的 Angular 组件库

    使用 Angular CLI 构建 Angular 应用程序是最方便的方式之一. 项目目标 现在,我们一起创建一个简单的组件库. 首先,我们需要创建一个 header 组件.这没什么特别的,当然接下来 ...

  7. MySQL 实现将一个库表里面的数据实时更新到另一个库表里面

    MySQL 实现将一个库表里面的数据实时更新到另一个库表里面 需求描述:MySQL 里面有很多的数据库,这些数据库里面都有同一种表结构的表 (tb_warn_log),这张表的数据是实时更新的,现在需 ...

  8. 爬虫 Http请求,urllib2获取数据,第三方库requests获取数据,BeautifulSoup处理数据,使用Chrome浏览器开发者工具显示检查网页源代码,json模块的dumps,loads,dump,load方法介绍

    爬虫 Http请求,urllib2获取数据,第三方库requests获取数据,BeautifulSoup处理数据,使用Chrome浏览器开发者工具显示检查网页源代码,json模块的dumps,load ...

  9. 划词标注1——使用svg绘制换行文本并自动识别库中字典数据

    业务需求 给出一段文本,自动识别出文本中包含的关键字信息,关键字是库里已知的数据,根据类型的不同显示出不同的颜色 业务分析 1)采用css:文本识别出来后,根据识别出的文本更改对应文本的dom,通过更 ...

随机推荐

  1. python的str,unicode对象的encode和decode方法(转)

    python的str,unicode对象的encode和decode方法(转) python的str,unicode对象的encode和decode方法 python中的str对象其实就是" ...

  2. HRBUST 1212 乘积最大

    $dp$,大数运算. $dp[i][j]$表示到$i$位置切成了$j$段的最大收益.数字爆$longlong$,$Java$上大数. import java.math.BigInteger; impo ...

  3. js判断上传图片宽高及文件大小

    <input id="file" type="file"> <input id="Button1" type=" ...

  4. NIO使用Reactor模式遇到的问题

    关于Reactor模式,不再多做介绍,推荐Doug Lea大神的教程:Java 可扩展的IO 本来在Reactor的构造方法中完成一系列操作是没有问题的: public class Reactor i ...

  5. ExtJs之列表(grid)

    --renderers渲染器 可以格式化该列显示的数据格式或者按照你自定义的脚本显示最终数据样子 先看下renderer: function()里的参数 renderer:function(value ...

  6. CentOS7编译安装PostgreSQL

    创建组和用户 groupadd postgres useradd -g postgres postgres passwd postgres 编译安装 yum install -y gcc gcc-c+ ...

  7. cogs 2039. 树的统计

    2039. 树的统计 ★★   输入文件:counttree.in   输出文件:counttree.out   简单对比时间限制:1 s   内存限制:128 MB [题目描述] 关于树的统计问题有 ...

  8. [BZOJ2669][CQOI2012]局部最小值(容斥+状压DP)

    发现最多有8个限制位置,可以以此为基础DP和容斥. $f_{i,j}=f_{i-1,j}\times (cnt_j-i+1)+\sum_{k\subset j} f_{i-1,k}$ $cnt_j$表 ...

  9. BZOJ 4260 Codechef REBXOR(字典树)

    [题目链接]  http://www.lydsy.com/JudgeOnline/problem.php?id=4260 [题目大意] 给出一个数列,请找出两段连续且不相交的数段,使得其分别异或和的和 ...

  10. 二叉搜索树BStree

    二叉搜索树,实际上是有点类似于二分查找.实际上很简单,就是递归.直接上代码,有点要注意的就是删除的时候,如果是左子树和右子树都存在的话,要寻找继承者(successor). import java.u ...