标准C++ I/O库 迭代器让数据自由流动 V8
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的更多相关文章
- c/c++ 标准库 迭代器(iterator)
c/c++ 标准库 迭代器 begin和end运算符返回的具体类型由对象是否是常量决定,如果对象是常量,begin和end返回const_iterator:如果对象不是常量,返回iteraotor 1 ...
- WebGIS中基于控制点库进行SHP数据坐标转换的一种查询优化策略
文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1.前言 目前项目中基于控制点库进行SHP数据的坐标转换,流程大致为:遍 ...
- Libscore – 收集 JavaScript 库的使用数据
Libscore 扫描网络上成千上万的网站,收集统计 JavaScript 库的使用数据.在搜索框中,输入关键词,例如 jQuery, Modernizr, $.ui 或者 $.fn.fancybox ...
- SQL Server跨库复制表数据错误的解决办法
SQL Server跨库复制表数据的解决办法 跨库复制表数据,有很多种方法,最常见的是写程序来批量导入数据了,但是这种方法并不是最优方法,今天就用到了一个很犀利的方法,可以完美在 Sql Serv ...
- 项目中通过Sorlj获取索引库中的数据
在开发项目中通过使用Solr所提供的Solrj(java客户端)获取索引库中的数据,这才是真正对项目起实质性作用的功能,提升平台的检索性能及检索结果的精确性 第一步,引入相关依赖的jar包 第二步,根 ...
- [转]使用 Angular CLI 和 ng-packagr 构建一个标准的 Angular 组件库
使用 Angular CLI 构建 Angular 应用程序是最方便的方式之一. 项目目标 现在,我们一起创建一个简单的组件库. 首先,我们需要创建一个 header 组件.这没什么特别的,当然接下来 ...
- MySQL 实现将一个库表里面的数据实时更新到另一个库表里面
MySQL 实现将一个库表里面的数据实时更新到另一个库表里面 需求描述:MySQL 里面有很多的数据库,这些数据库里面都有同一种表结构的表 (tb_warn_log),这张表的数据是实时更新的,现在需 ...
- 爬虫 Http请求,urllib2获取数据,第三方库requests获取数据,BeautifulSoup处理数据,使用Chrome浏览器开发者工具显示检查网页源代码,json模块的dumps,loads,dump,load方法介绍
爬虫 Http请求,urllib2获取数据,第三方库requests获取数据,BeautifulSoup处理数据,使用Chrome浏览器开发者工具显示检查网页源代码,json模块的dumps,load ...
- 划词标注1——使用svg绘制换行文本并自动识别库中字典数据
业务需求 给出一段文本,自动识别出文本中包含的关键字信息,关键字是库里已知的数据,根据类型的不同显示出不同的颜色 业务分析 1)采用css:文本识别出来后,根据识别出的文本更改对应文本的dom,通过更 ...
随机推荐
- Javascript备忘录-枚举一个对象的所有属
for...in 循环 var obj = { age: 18, fname: "Rand ", lname: "McKinnon" }; function s ...
- 2.Spark Streaming运行机制和架构
1 解密Spark Streaming运行机制 上节课我们谈到了技术界的寻龙点穴.这就像过去的风水一样,每个领域都有自己的龙脉,Spark就是龙脉之所在,它的龙穴或者关键点就是SparkStreami ...
- JQuery动态添加多个tab页标签
jQuery是一个兼容多浏览器的js库,核心理念是write less,do more(写的更少,做的更多),jQuery使用户能更方便地处理HTML documents.events.实现动画效果, ...
- 运行时候报异常could only be replicated to 0 nodes instead of minReplication (=1). There are 2 datanode(s) running and no node(s) are excluded in this operation.
运行时候报异常could only be replicated to 0 nodes instead of minReplication (=1). There are 2 datanode(s) ...
- [P1640][SCOI2010]连续攻击游戏
Link: P1640 传送门 Solution: 可以发现这道题其实是属性值集合和装备集合的对应,且每个点只能用一次 那么就能想到二分图最大匹配,一旦不可行直接退出就行了 Tip: 1.$Hungr ...
- BZOJ 3450 Tyvj1952 Easy(期望)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3450 [题目大意] 给出一个字符串,包含o,x和?,一个字符串的得分为 每段连续的o的 ...
- BZOJ 1066 [SCOI2007]蜥蜴(最大流)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1066 [题目大意] 在一个r行c列的网格地图中有一些高度不同的石柱,一些石柱上站着一些 ...
- 【推导】【DFS】Codeforces Round #429 (Div. 1) B. Leha and another game about graph
题意:给你一张图,给你每个点的权值,要么是-1,要么是1,要么是0.如果是-1就不用管,否则就要删除图中的某些边,使得该点的度数 mod 2等于该点的权值.让你输出一个留边的方案. 首先如果图内有-1 ...
- Java高级架构师(一)第33节:Nginx常用核心模块指令
error_log:错误日志级别 http://www.nginx.cn/doc/ Nginx中文文档 # 并发总数是 worker_processes 和 worker_connections 的 ...
- (转)Hadoop系列-IPC模型
学习笔记Mark IPC 实现RPC的一种方法,具有快速.简单的特点. 它不像Sun公司提供的标准RPC包,基于Java序列化. IPC无需创建网络stubs和skeletons. IPC中的方法调用 ...