istream_iterator和ostream_iterator学习体会

article/2025/10/10 0:11:22

istream_iterator 在<iterator>头文件的定义中

定义istream_iterator变量的方法为

istream_iterator<T> in(strm);    (其中T指明此istream_iterator的输入类型 , strm为istream_iterator指向的流)

提供了输入操作符(>>)和 输出操作符 (<<)的任何类型都可以创建 istream_iterator 对象和ostream_iteratorcfq对象,即对自己的类重载了这两个函数:

istream &operator >> (istream &is, &MyClass c);

和 ostream &operator << (ostream &os , const  &MyClass c);

1. 若strm为空时,即比如istream<T> in();时,  此时变量in 就相当于指向EOF标志的iterator了

如图如下定义: (下文的eoff是我故意这样写的,只是为了让大家明白这个名字随便起都行)

istream_iterator<T> eoff ;

发现eoff的私有变量中_Myistr为0x000000000;

再看看一个定义: (注意:test.txt的内容为10(EOF) )

	ifstream infile("f:\\test.txt");istream_iterator<int> input(infile);

再用vs2008调试时查看:


大家发现没有:input变量的私有成员_Myistr不为0了! 且私有成员_Myval正好为10(即文件中的第一个整型数)

现在在执行下一行代码:

	++input;

再用VS2008看看input的成员:


++input后,其私有成员_Myistr变为0x00000000了!和之前定义的eoff变量一样了!

再执行下一行看看会输出什么:

	cout<<(in == eoff ? "EOF" : "others")<<endl;
显然此时的in == eoff 成立,结果输出的是 "EOF"  

现在我们知道了copy(input,eoff,back_inserter(ivec)这么用法的原因了吧。  因为copy函数是通过input先与eoff比较是否相等,若不等则将其解引用(*input)插入到ivec的最后

然后再自加1,再与eoff比较.   直到与eoff比较相等时结束! 所以用未用流初始化的istream_iterator作为哨兵.

copy(istream_iterator<int>(cin),istream_iterator<int>(),back_inserter(ivec)也是一样的情况。 需要结束时按下ctrl+z产生EOF标志  ^z

完整程序如下:

#include <iostream>
#include <vector>
#include <fstream>
#include <iterator> //istream_iterator,ostream_iterator,back_inserter
#include <algorithm> //copy
#include <Windows.h> //system
using namespace std;
int main()
{istream_iterator<int> eoff;ifstream infile("f:\\test.txt"); //运行前,请让f:\\test.txt里面只有一个整数istream_iterator<int> input(infile);cout<<"the first element:"<<*input<<endl;++input;cout<<(input == eoff ? "EOF" : "others")<<endl;cout<<"*******************"<<endl;cout<<"请输入整数,按ctrl+z结束输入:"<<endl;vector<int> ivec;copy(istream_iterator<int>(cin),istream_iterator<int>(),back_inserter(ivec));//下句为将ivec内容输出屏幕copy(ivec.begin(),ivec.end(),ostream_iterator<int>(cout,"\t"));system("pause");
}


ps: istream_iterator 和 ostream_iterator 都没有定义自减运算,即 --input; 是错误的!

2. 注意了如果对于istream_iterator<int> 型,如果文件里面是为字母的话,input会如何呢? 

在此之前,请把f:\test.txt的加一个字母看什么情况 即内容为: 10   sfd(EOF)

	istream_iterator<int> eoff;ifstream infile("f:\\test.txt"); //运行前,请让f:\\test.txt里面只有一个整数istream_iterator<int> input(infile);cout<<"the first element:"<<*input<<endl;++input;

运行这几句后,istream_iterator<int> input(infile)应该只能指向整型,但现在为字母了,会如何呢?

我们看看现在的input的成员:

input遇到字母时,_Myistr也变为0x00000000了。那么是不说

	cout<<(input == eoff ? "EOF" : "others")<<endl;
也会输入“EOF”,即input == eoff呢?  答案确实是肯定的!

其实此时的cin.good()也为false了. 大家可以加一行代码试试:cout<<cin.good()<<endl;

现在我们知道了,当只需要整型时,使用istream_iterator<int> (cin)输入时,也可以输入一个非int型的字母来终结输入。


对于ostream_iterator<T> ouput(strm,"xxx");也是一样,只是现在的output为左值为:

例如:

ostream_iterator<int> output(cout," : ");
*output = 5;
*output = 6;

或者这样写

	ostream_iterator<int> output(cout," : ");*output++ = 5;*output++ = 6;
其结果都是:5 : 6

output每次解引用 *output后赋值后,都会使自己自加1  。

也就是说不用自己使用 *output++ 的方法了。



总之:

这两句是最好用的了:

	copy(istream_iterator<int>(cin),istream_iterator<int>(),back_inserter(ivec));//下句为将ivec内容输出屏幕copy(ivec.begin(),ivec.end(),ostream_iterator<int>(cout,"\t"));

输入那句更好的是

vector<int> ivec(istream_iterator<int>(cin),istream_iterator<int>());

这句更简洁.

若写的有问题,请各位大侠指教。

转载请注明出处.



http://chatgpt.dhexx.cn/article/VkUTpA10.shtml

相关文章

Stream

Java8 的 Stream 流&#xff0c;加上 Lambda 表达式&#xff0c;可以让代码变短变美&#xff0c;还是变短变丑&#xff1f; 距离Java 8发布已经过去了7、8年的时间&#xff0c;Java 19也发布了。Java 8中关于函数式编程和新增的Stream流API至今饱受“争议”。 如果你不曾使用…

istream_iterator 和 ostream_iterator

C primer代码学习 通过istream_iterator 绑定标准输入 cin 通过ostream_iterator 绑定标准输出 cout #include <iterator> using std::istream_iterator; using std::ostream_iterator;#include<vector> using std::vector;#include<iostream> using std::c…

C++重载istream和ostream

对于一般的运算符重载&#xff0c;可以重载为类的成员函数&#xff0c;这是因为操作符的第一个元素一定是本类的对象&#xff08;this&#xff09; 例如 #include<iostream> using namespace std;class book { public:book (int n):bookNo(n) {}int getBookNo () {retu…

【C++初阶】ostream、operater<<、operator<<(ostream _cout, const Date d)、bool引导的结构体内嵌比较函数解析

对C重载、判断部分的知识进行梳理 目录 一、bool operator>(const Date& d) const【bool引导的结构体内嵌比较函数】 1.代码整体含义 2.代码两个const的含义 二、friend ostream& operator<<(ostream& _cout, const Date& d) 1. 相关基础概念 …

C++ iostream、ostream、istream等标准库都是什么?看完这篇就知道了

目录 iostream 库组成基本类模板类模板实例标准对象类型操纵符 源码 ostream 库istream 库fstream 库ios 库 我们在写C代码的时候&#xff0c;总会用到 iostream 库&#xff0c;这是C的标准库&#xff0c;几乎每个程序都会用到它&#xff08;有一些人则会用 cstdio &#xff…

C++之 ostream详细用法

概述 在 C中&#xff0c;ostream表示输出流&#xff0c;英文”output stream“的简称。在 C中常见的输出流对象就是标准输出流cout&#xff0c;很少自定义ostream的对象&#xff0c;更多的是直接使用cout。那么 ostream 有什么用呢&#xff0c;来看一个场景&#xff1a; clas…

Simple_SSTI_1

Simple_SSTI_1&#xff1a; 打开题目 查看一下网页源代码 flag在secret_key下 以get方式传递参数flag{{config.SECRET_KEY}}即得到flag。 也就是114.67.246.176.12930/?flag{{config.SECRET_KEY}} SECRET_KEY是config配置里面的一个值 告自己&#xff1a;要先截图再提交flag…

SSTI(模板注入) 解析 和 ctf 做法

基础知识补充&#xff1a; __class__ 返回类型所属的对象__mro__ 返回一个包含对象所继承的基类元组&#xff0c;方法在解析时按照元组的顺序解析。__base__ 返回该对象所继承的基类// __base__和__mro__都是用来寻找基类的__subclasses__ 每个新类都保留了子类的引用&#xff…

SSTI注入————php的SSTI

SSTI 就是服务器端模板注入&#xff08;Server-Side Template Injection&#xff09; ​ 当前使用的一些框架&#xff0c;比如python的flask&#xff0c;php的tp&#xff0c;java的spring等一般都采用成熟的的MVC的模式&#xff0c;用户的输入先进入Controller控制器&#xff0…

SSTI

模板注入在py2和py3中有些不同&#xff0c;但是没有本质上的区别。 模板注入的流程&#xff1a;找到父类<type ‘object’>–>寻找子类–>找关于命令执行或者文件操作的模块。 几个魔术方法&#xff1a; class 返回类型所属的对象 mro 返回一个包含对象所继承的基类…

SSTI模板注入及绕过姿势(基于Python-Jinja2)

前言&#xff1a;​SSTI&#xff08;服务端模板注入&#xff09;&#xff0c;已然不再是一个新话题&#xff0c;近年来的CTF中还是也经常能遇到的&#xff0c;比如护网杯的easy_tonado、TWCTF的Shrine&#xff0c;19年的SCTF也出了Ruby ERB SSTI的考点&#xff1b;本篇对这部分…

SSTI (服务器模板注入)

先来一波flask ssti漏洞的代码。 #python3 #Flask version:0.12.2 #Jinja2: 2.10 from flask import Flask, request from jinja2 import Template app Flask(__name__) app.route("/") def index():name request.args.get(name, guest)t Template("Hello &…

初步认识SSTI

SSTI简介 SSTI&#xff0c;即服务端模板注入&#xff0c;起因是服务端接收了用户的输入&#xff0c;将其作为 Web 应用模板内容的一部分&#xff0c;在进行目标编译渲染的过程中&#xff0c;执行了用户插入的恶意内容&#xff0c;从而导致各种各样的问题。 Python SSTI(flask…

ISCC SSTI

先找参数吧&#xff0c;通过信息搜集&#xff0c;参数是xiaodouni 就是小豆泥的英文&#xff0c;这个是暹罗猫的一个名字吧 然后直接放两个payload的吧 看不懂的可以看一下我以前的文章CTFshow ssti里面讲了思路&#xff0c;这里就不再解释了。 {%set pp(dict(popa))|join%} …

SSTI 学习笔记

PHP SSTI(Twig) 学习文章 进入环境&#xff0c;左上角有flag,hint 都检查看看 flag页面显示ip&#xff0c;hint页面源代码有提示 考虑XFF头或者referer头 测试一下 注&#xff1a;这里不用加上“&#xff1b;” 出来了 python flask ssti 学习文章 原理&#xff1a;因为对输…

浅学Go下的ssti

前言 作为强类型的静态语言&#xff0c;golang的安全属性从编译过程就能够避免大多数安全问题&#xff0c;一般来说也唯有依赖库和开发者自己所编写的操作漏洞&#xff0c;才有可能形成漏洞利用点&#xff0c;在本文&#xff0c;主要学习探讨一下golang的一些ssti模板注入问题…

SSTI——java里的ssti

1.Velocity 2.FreeMarker 因为从来没接触过java语言 所以对这些也是基本上一窍不通 这里只简单的提及 不做具体介绍 会找一下题来做 但是没有找到有关java ssti的题目 confusion1 看一下描述 打开题目 没发现什么东西 但是 login register页面显示访问不成功 查看源代码找到…

详解SSTI模板注入

详解SSTI模板注入 SSTI简介常见的模板引擎PHPJAVAPYTHONRUBYGOLANG SSTI产生的原因常用检测工具 TplmapFlask/Jinja模板引擎的相关绕过Flask简介demo漏洞代码基础知识沙盒逃逸Python的内建函数名称空间类继承 寻找Python-SSTI攻击载荷的过程攻击载荷过程常用的目标函数常见的中…

web安全-SSTI模板注入漏洞

一.初识SSTI 1.什么是SSTI注入&#xff1f; SSTI模板注入(Server-Side Template Injection)&#xff0c;通过与服务端模板的输入输出交互&#xff0c;在过滤不严格的情况下&#xff0c;构造恶意输入数据&#xff0c;从而达到读取文件或者getshell的目的。 2.SSTI漏洞成因 ​…

BugKu:Simple_SSTI(SSTI模板注入)

目录 1.Simple_SSTI_1 2.Simple_SSTI_2 1.Simple_SSTI_1 点击链接进入&#xff0c;题目说&#xff1a; You need pass in a parameter named flag。(你需要传入一个名为flag的参数)然后我们可以直接f12查看&#xff0c;也可以右击页面--->“检查” 如图所示&#xff0c;我…