cin与cout

一:标准输入函数cin

不知道说它是个函数对还是不对,它是代表标准的输入设备--键盘。他是属于流的,他的用法和流的用法是一样的。也就是:cin>>变量;

小小的说明一下,输入多个变量可以写在一行,如:cin>>x>>y>>z;

这样写不是不允许,而是不好看,如果是不同的变量类型,那就更是没头没脑了。除了你,人家是不知道该输入什么的,所以,一般在输入语句的前面,我们一般都

要做一个提示,请输入×××,让人家心里有个底,知道这个变量是做什么的。

另外,这个函数是不用带地址符号"&"的,也不用写明变量类型,千万不要跟scanf混淆。当然他就也不检查变量输入是否合法。如:

int i;

cout<

cin>>i;

cout<

如果你输入的是一个字符如'a'那么他也不检查,但你输出的结果不是正确的,这要是手工进行检查。当然他也跟scanf一样,如果在循环内部输入不合法的变量值,那么也将陷入死循环。如下:

/*一个输入不合法变量陷入死循环的例子*/

#include

main()

{

int i;

while(i!=-1)

{

cout<

cin>>i; /*请输入不是一个字符如'a'试试*/

cout<

}

}

如上一个程序,如果你输入的不合法,那就将陷入死循环。解决的办法有个一,把cin>>i;语句移到判断循环的语句中,那么,你输入的如果是不合法的变量,他将跳出循环。

cin是用空格来分隔输入的。请看看如下的例子:

/*一个空格分隔使输入的变量达不到希望的值*/

#include

main()

{

char str[20];

cout<

cin>>str; /*你试着输入"hello word"*/

cout<

}

看得到是什么结果呢?得到的仅仅是str=hello,为什么呢?因为cin是以空格为分隔的,当你输入一个空格时,那他就认为后面的输入不属于这里了,

认为应该给后面的变量了。另外,当你输入的字符串大于分配的空间时,还会出现溢出现象。当然,还有整行输入的函数,包括空格也一起输入了,以后也会学到。

二、标准输出函数cout

说cout是函数,也跟cin一样,不知道对不对。他代表的是标准输出设备--显示器。其实前面已经用过很多次这个函数了。我们就通过一个例子来进行格式化的输出就是了,大家就体会体会这个例子就行了,比printf灵活了很多。

首先,我们可以按16进制,8进制和10进制来显示我们的数据,如下:

/*一个按进制输出的例子*/

#include

void main()

{

int x=30, y=300, z=1024;

cout<

cout.unsetf(ios::dec ); //取消十进制输出设置

cout.setf(ios::showbase | ios::uppercase); //设置基指示符输出和数值中的字母大写输出

cout<

cout.unsetf(ios::showbase | ios::uppercase); //取消基指示符输出和数值中的字母大写输出

cout.setf(ios::oct); //设置为八进制输出,此设置不取消一直有效

cout<

cout.setf(ios::showbase | ios::uppercase); //设置基指示符输出和数值中的字母大写输出

cout<

cout.unsetf(ios::showbase | ios::uppercase); //取消基指示符输出和数值中的字母大写输出

cout.unsetf(ios::oct); //取消八进制输出设置,恢复按十进制输出

cout.setf(ios::hex); //设置为十六进制输出

cout<

cout.setf(ios::showbase | ios::uppercase); //设置基指示符输出和数值中的字母大写输出

cout<

cout.unsetf(ios::showbase | ios::uppercase); //取消基指示符输出和数值中的字母大写输出

cout.unsetf(ios::hex); //取消十六进制输出设置,恢复按十进制输出

cout<

}

我们用cout.setf()设置输出的格式,用cout.unsetf()取消格式。可以看出10进制在输出的时候不管有没有设置基指示符ios::

showbase,都没用,8进制再输出的时候在前面加0,而16进制是在前面加0X。而对于数值中字母大写输出,只对16进制有用,以后我们就应该看情

况使用了。当然,我们前面已经说了,还有一种方法也可以实现格式化输出,那就是使用操纵算子,如下,

/*一个按进制输出的例子*/

#include

void main()

{

int x=30, y=300, z=1024;

cout<

cout<

cout<

cout<

cout<

cout<

cout<

//设置基指示符和数值中的字母大写输出,

cout<

cout<

//取消基指示符和数值中的字母大写输出

cout<

cout<

}

我们用以上的程序也可以输出同样的结果,可见他的灵活。我们现在输出下列一段文字:

第一章

1.1 什么是C语言...........................1

1.11 C语言的历史..........................58

第二章

方法很多种啦,我们可以这样写:

/*一个使用填充,宽度,对齐方式的例子*/

#include

void main()

{

cout<

cout<

cout.setf(ios::left); //设置对齐方式为left

cout.width(7); //设置宽度为7,不足用空格填充

cout<

cout<

cout.unsetf(ios::left); //取消对齐方式,用缺省right方式

cout.fill('.'); //设置填充方式

cout.width(30); //设置宽度,只对下条输出有用

cout<<1<

cout<

cout.width(7); //设置宽度

cout.setf(ios::left); //设置对齐方式为left

cout.fill(' '); //设置填充,缺省为空格

cout<

cout<

cout.unsetf(ios::left); //取消对齐方式

cout.fill('.');

cout.width(30);

cout<<58<

cout.fill(' ');

cout<

}

我们多次设置了宽度,为的是使我们的间距能一致,也使用了对齐方式,为的是使我们的数据能对齐显示,看起来美观。我们还使用了填充方式。我们下面用操纵算子来实现也是可以的。

/*一个使用填充,宽度,对齐方式的例子*/

#include

void main()

{

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

}

我们输出了同样的效果,不过依我的性格,我更喜欢用操纵算子来进行格式化输出。最后我们看看浮点数的格式输出,如下例:

/*关于浮点数的格式*/

#include

void main()

{

float f=2.0/3.0,f1=0.000000001,f2=-9.9;

cout<

cout.setf(ios::showpos); //强制在正数前加+号

cout<

cout.unsetf(ios::showpos); //取消正数前加+号

cout.setf(ios::showpoint); //强制显示小数点后的无效0

cout<

cout.unsetf(ios::showpoint); //取消显示小数点后的无效0

cout.setf(ios::scientific); //科学记数法

cout<

cout.unsetf(ios::scientific); //取消科学记数法

cout.setf(ios::fixed); //按点输出显示

cout<

cout.unsetf(ios::fixed); //取消按点输出显示

cout.precision(18); //精度为18,正常为6

cout<

cout.precision(6); //精度恢复为6

}

同样,我们也一样能用操纵算子实现同样的功能:

/*关于浮点数的格式*/

#include

void main()

{

float f=2.0/3.0,f1=0.000000001,f2=-9.9;

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

}

在c/c++系统中除了标准的输入输出外,还提供了更多的输入函数。这写函数主要有getch(),getche(),

getchar

(),cin.get(),putch(),putchar(),cout.put(),gets(),cin.getline(),puts()。另外

还有些为了让缓冲区不影响程序的正确操作的缓冲去的操作,如:cin.putback(),fflush(stdin),cout.flush().我们

做一下简单的说明。

1、getch()和getche(),非缓冲式输入,从键盘读入一个字符。getch()读入字符不显示。有conio.h支持。

2、cin.get(),getchar(),缓冲式输入,从键盘读入一个字符,并显示。getchar()由stdio.h支持,cin.get()由iostream.h支持。

3、putch()和putchar(),非缓冲式输出,输出一个字符到显示器。putch()由conio.h支持,putchar()由stdio.h支持。

4、cout.put(),缓冲式输出,输出一个字符到显示器。由iostream.h支持。

5、gets()和cin.geline(),缓冲式输入,读入一字符串(包括空格,不包括最后的回车),gets()由stdio.h支持,cin.getline()由iostream.h支持。

6、puts(),非缓冲输出,输出一个字符串,由stdio.h支持。

7、cin.putback(),把一个字符送回输入缓冲区。

8、fflush(stdin),清除输入缓冲区操作。无法清除cin.get()等带来的操作。

9、cout.flush(),清楚输出缓冲区。

在这里我们稍微说一下输入/输出缓冲区,这是为了减少程序访问io带来中断而设的一段空间。当程序满足某个刷新条件时,那就将清理缓冲区。具体条件为:

1、输入缓冲区

a,程序要求输入时,按下了回车键。

b,遇到程序结束。

c,遇到下一条输入语句。

d,遇到清除缓冲区操作

e,缓冲区溢出

2、输出缓冲区

a,输出缓冲区溢出

b,遇到下一条输入语句

c,使用刷新缓冲区迫使清除

d,程序结束。

缓冲区操作有时会带来程序的不正确的输入,如前面说的scanf(),在连续输入的时候,会把一个回车赋给下一个字符变量。我们操作的时候一定要注意。

c语言cout函数,c++中cin与cout 详解相关推荐

  1. python数据处理常用函数_pytorch中的自定义数据处理详解

    pytorch在数据中采用Dataset的数据保存方式,需要继承data.Dataset类,如果需要自己处理数据的话,需要实现两个基本方法. :.getitem:返回一条数据或者一个样本,obj[in ...

  2. mysql iif函数_sql中的iif语句详解_mysql

    IIf 返回由逻辑测试确定的两个数值或字符串值之一. 语法 数字 IIf(«Logical Expression», «Numeric Expression1», «Numeric Expressio ...

  3. c语言getline作用,C++中getline()的用法详解

    getline()用法 getline是C++标准库函数:它有两种形式,一种是头文件< istream >中输入流成员函数:一种在头文件< string >中普通函数: 它遇到 ...

  4. C语言 定义函数妇女 判定整数n,【详解】C语言:编写一个函数itob(int n,char s[], int b),将整数n转换为以b进制的数。保存到s中。...

    #include void itob(int n,char s[], int b) { int i=1; for(;i<=32;i++)    //共循环了32次,保证得到32位的二进制数 { ...

  5. c语言 unique函数,C++ unique(STL unique)算法详解

    unique() 算法可以在序列中原地移除重复的元素,这就要求被处理的序列必须是正向迭代器所指定的.在移除重复元素后,它会返回一个正向迭代器作为新序列的结束迭代器.可以提供一个函数对象作为可选的第三个 ...

  6. js 将内部函数变成全局函数_js中三种作用域详解(全局,函数,块级)

    1.全局变量:声明在函数外部的变量(所有没有var直接赋值的变量都属于全局变量) 2.局部变量:声明在函数内部的变量(所有没有var直接赋值的变量都属于全局变量) JS中变量申明分显式申明和隐式申明. ...

  7. python中deepcopy函数_python中copy()和deepcopy()详解

    **首先直接上结论: -–我们寻常意义的复制就是深复制,即将被复制对象完全再复制一遍作为独立的新个体单独存在.所以改变原有被复制对象不会对已经复制出来的新对象产生影响. -–而浅复制并不会产生一个独立 ...

  8. time库是python中处理时间的标准库_python语言time库和datetime库基本使用详解

    今天是边复习边创作博客的第三天,我今年大二,我们专业开的有这门课程,因为喜欢所以更加认真学习,本以为没人看呢,看了后台浏览量让我更加认真创作,这篇博客花了2个半小时的时间,结合自己所学,所思,所想写作 ...

  9. c语言排序常用问题,【更新中】【排序详解】解决排序问题(以C语言为例)

    [更新中][排序详解]解决排序问题(以C语言为例) [更新中][排序详解]解决排序问题(以C语言为例) 文章目录 排序的相关概念 简单排序 一.插入排序: (一)插入排序基本思想 (二)插入排序基本操 ...

  10. python中的super用法详解_Python中super函数用法实例分析

    本文实例讲述了python中super函数用法.分享给大家供大家参考,具体如下: 这是个高大上的函数,在python装13手册里面介绍过多使用可显得自己是高手 23333. 但其实他还是很重要的. 简 ...

最新文章

  1. python做项目看板_三、使用python数据仓库实现可视化看板
  2. 平时学习中的拙作,希望交更多的朋友,希望得到更多的指导和交流
  3. Go的marshal unmarshal
  4. 【solr专题之四】关于VelocityResponseWriter
  5. 希尔排序+移位法(吊打交换法)
  6. android动画详解
  7. redis常用命令与特性
  8. 用Docker部署TensorFlow Serving服务
  9. 设置 ASP.NET 存储当前应用程序的临时文件(生成的源、编译了的程序集等)的目录的物理路径。...
  10. C++异常处理的开销
  11. Grails 技巧 - View 篇
  12. 测试驱动开发(TDD)实践与技巧
  13. 初识阿里云环境搭建:无法远程连接,入过的坑:服务器ping不通,FTP搭建,服务器搭建数据库,远程连接服务器数据库
  14. 基于高德地图API — 绘制热力图初尝试
  15. iOS常用的功能(打电话、发短信、发邮件等)
  16. Redis源码学习(14),t_set.c 学习(二),sismember,scard,spop 命令学习
  17. python获取股指_用Python读取csv文件中的沪深300指数历史交易数据
  18. mysql创建用户只能访问数据库中一张表
  19. 剩余运算符和展开运算符
  20. 【codecs】视频显示分辨率格式分析

热门文章

  1. STM32F103实现OV7725拍照存储为BMP位图
  2. 项目突发事件识别_当突发事件发生时,您要做的就是文化
  3. 做个jmeter登陆百度网盘的实例
  4. 软件开发之大忌:想当然
  5. 【详细】【转】CentOS 7部署ASP.NET Core应用程序
  6. SQL :Date 函数
  7. SpringBoot整合grpc
  8. 全文检索——Lucene
  9. 安装ubuntu中出现的问题(xshell无法连接虚拟机中的ubuntu、nat模式无法ping主机和外网)
  10. 谷歌Mediapipe运行环境配置