C++ 输入输出流 总结
1.ostream & operator<<(int);
重载了<<符号,用于对int类型的输出。为什么要返回ostream的引用呢?
例如:
cout<< "1122" << "2345" <<endl;
那么当输出“1122"的时候,返回了cout,也就是: cout<<"1122"返回为 cout,然后可以继续像cout<<"2345"<<endl;这样输出。
2.对数组和指针的输出
ostream可以对下面的指针类型进行输出:
const signed char *
const unsigned char *
const char *
void * //打印地址的数值表示
eg:
char a[]="sdwadwada" //int类型是不能这么打印的 智能对char数组 cout<<a<<endl; // 显示:sdwadwada char* a="sdwadwada" cout<<a<<endl; //sdwadwada cout<<&a<<endl;//打印的是地址 cout<<(void *)a<<endl; //打印的是地址
3.
std::cout.put(66.5); //B
std::cout.put(65); //A
return 0;
4.强制转换
long val=560031841;
cout.write((char*) & val, sizeof(long)); //讲显示4个字符形式的数据
过程是:先取数字的地址强制转换为char*类型
5.cin输入
检查输入: 它们跳过空白(空格、换行符和制表符)直到遇到非空白字符开始。
读取范围: 它们读取从非空白字符开始到与目标类型不匹配的第一个字符之间的全部内容。
char a[20];
int b;
char c;
cin>> a >> b >> c;
输入: yuandedong 123 h
a: yuandedong
b: 123
c: h
读完yuandedong后 就返回cin 相当于cin>>b>>c; 因此不可能将h读到a中。
6.cin输入的注意事项
看下例:
结果如下图:
,不能继续输入New num。
原因: 当读取到文件尾部的时候,也就是最开始输入完了后, 流状态将eofbit设置为1,只有当eofbit、badbit、failbit都为0的时候一切才是顺利的。才可以继续读下去。因此我们可以接下来使用cin.clear()对stream状态进行重置。
如下:
7.get cin 的用法
get(char &) 和get(void ) 方法提供了不跳过空白的单字符输入功能。
get(char *, int , char)和getline(char *, int , char)在默认情况下读取整行而不是一个单词。
它们都不会跳过空白,也不会进行数据转换。
cin跳过空白(空格、换行符和制表符)直到遇到非空白字符开始。
版本2:
void main() { char ch; while(cin.get(ch)) { cout<<ch<<" "; } }
版本3:
char ch;
ch=cin.get();
while(ch!='\n')
{
cout<<ch<<" "
ch=cin.get();
}
到达文件尾后,cin.get(void)都将返回值EOF,因此可以这样来读取输入:
将ch类型申明为int而不是char,因为值EOF可能无法使用char类型来表示。
由以上实验结果可以得出:
1.cin确实跳过了空白格,结束符也给跳过了进入了无限循环。
8. 文件输入输出
8.1 头文件: fstream
包含该文件便自动包含iostream文件,因此不必显示包含iostream头文件。
ostream是ofstream的基类,istream同样,因此可以使用所有的ostream的方法,包括插入操作符定义、格式化方法和控制符等等。
eg:
ifstream fin(".....txt");
char ch;
while(fin.get(ch)) //和cin的方法是一样的。
{
....
}
if(!fin.is_open())
{
...
}
8.2 打开多个文件
cin.clear()也可以不要,视情况而定。
命令行处理:
C++ 输入输出流 总结的更多相关文章
- java.IO输入输出流:过滤流:buffer流和data流
java.io使用了适配器模式装饰模式等设计模式来解决字符流的套接和输入输出问题. 字节流只能一次处理一个字节,为了更方便的操作数据,便加入了套接流. 问题引入:缓冲流为什么比普通的文件字节流效率高? ...
- Java中IO流,输入输出流概述与总结
总结的很粗糙,以后时间富裕了好好修改一下. 1:Java语言定义了许多类专门负责各种方式的输入或者输出,这些类都被放在java.io包中.其中, 所有输入流类都是抽象类InputStream(字节输入 ...
- 第27章 java I/O输入输出流
java I/O输入输出流 1.编码问题 import java.io.UnsupportedEncodingException; /** * java涉及的编码 */ public class En ...
- java 对象输入输出流
对象的输入输出流的作用: 用于写入对象 的信息读取对象的信息. 对象的持久化. 比如:用户信息. ObjectInputStream : 对象输入流 ...
- 【转】输入/输出流 - 全面掌握IO
File类: 程序中操作文件和目录都可以使用File类来完成即不管是文件还是目录都是使用File类来操作的,File能新建,删除,重命名文件和目录,但File不能访问文件内容本身,如果需要访问文件本身 ...
- 输入输出流(IO)
输入输出流(IO)文件(File)java.io.File用于表示文件(目录),也就是说程序员可以通过File类在程序中操作硬盘上的文件和目录.File类只用于表示文件(目录)的信息(名称.大小等), ...
- Java输入/输出流体系
在用java的io流读写文件时,总是被它的各种流能得很混乱,有40多个类,理清啦,过一段时间又混乱啦,决定整理一下!以防再忘 Java输入/输出流体系 1.字节流和字符流 字节流:按字节读取.字符流: ...
- JAVA Io 缓冲输入输出流
java中提供带缓冲的输入输出流.在打开文件进行写入或读取操作时,都会加上缓冲,提高了IO读写性能. 1. BufferedInputStream 缓冲输入流 2. BufferedOutputStr ...
- C++输入输出流
一.C++输入输出流的含义 以前所用到的输入和输出,都是以终端为对象的,即从键盘输入数据,运行结果输出到显示器屏幕上.从操作系统的角度看,每一个与主机相连的输入输出设备都被看作一个文件.程序的输入指的 ...
- Java 输入输出流 转载
转载自:http://blog.csdn.net/hguisu/article/details/7418161 1.什么是IO Java中I/O操作主要是指使用Java进行输入,输出操作. Java所 ...
随机推荐
- GitHub 有哪些优秀的项目
GitHub 有哪些优秀的项目 http://www.zhihu.com/question/20584141
- 你不需要jQuery(三):新AJAX方法fetch()
XMLHttpRequest来完成ajax有些老而过时了. fetch()能让我们完成类似 XMLHttpRequest (XHR) 提供的ajax功能.它们之间的主要区别是,Fetch API 使用 ...
- poj The Clocks 高斯消元
由于数据量不大,所以这题有很多解法. 我用的是高斯消元化为逆矩阵解决的…… 代码如下: #include<stdio.h> #include<iostream> using n ...
- EasyUI combotree值的设置 setValue
如果combotree的json数据如下: [ { "id":"2", "text":"wwwww", "st ...
- cocos2d-x 多分辨率适配详解(转载),以前北京团队设计的游戏,也是用这套方案
http://blog.csdn.net/kyo7552/article/details/17163487 多种分辨率的适配一直都是一个蛋疼的问题,各家公司可能都有自己的一套方案.今天我为大家介绍的是 ...
- 最受欢迎的5个Android ORM框架
在开发Android应用时,保存数据有这么几个方式, 一个是本地保存,一个是放在后台(提供API接口),还有一个是放在开放云服务上(如 SyncAdapter 会是一个不错的选择). 对于第一种方式, ...
- WinCE启动失败的原因与解决办法分析
本文通过一个真实的嵌入式项目进行说明.文中的嵌入式系统用的是ARM处理器+WinCE平台,项目的目的是要把WinCE平台从旧版本移植到WinCE6.0平台上.但结果是这个WinCE系统在启动的时候经常 ...
- Hive简介
实验简介 我们本节课程主要介绍 Hive 的相关知识,将会涉及以下内容: Hive 的定义 Hive 的体系结构 Hive 与关系数据库的区别 Hive 的应用场景 Hive 的存储 一.什么是 Hi ...
- node安装插件方法
node安装插件方法有几种,这里列出常用的两种方法: 方法1: 进入要安装插件的目录,直接用 npm 软件安装包安装,如(安装express): cd /project npm install -g ...
- poj 2195 Going Home(最小费用最大流)
题目:http://poj.org/problem?id=2195 有若干个人和若干个房子在一个给定网格中,每人走一个都要一定花费,每个房子只能容纳一人,现要求让所有人进入房子,且总花费最小. 构造一 ...