cc++标准输入输出语句

如题所述

第1个回答  2014-10-20
C语言输入输出总结
C语言中基本的输入输出函数有:
putchar ():把变量中的一个字符常量输出到显示器屏幕上;
getchar ();从键盘上输入一个字符常量,此常量就是该函数的值; printf ();把键盘中的各类数据,加以格式控制输出到显示器屏幕上; scanf ();从键盘上输入各类数据,并存放到程序变量中;
puts ():把数组变量中的一个字符串常量输出到显示器屏幕上;
gets ():从键盘上输入一个字符串常量并放到程序的数组中.
putchar() 和 getchar()就是从输入流中获取一个字符和输出一个字符。 例子如下:
char c = getchar();
putchar(c);
printf():
一般形式:
printf("格式控制".输出列表);
例如 : printf("a=%d,b=%f,c=%c\n",a,b,c);
1;格式控制.
格式控制是用双引号括起来的字符串,包含以下两部分信息.
(1)、格式说明:由"%"和格式字符组成,如%d,%f,%c,他的作用是把输出数据转换为指定格式输出,格式的说明总是由"%"字符开始的.
(2)、普通字符:需要原样输出的字符,或者是一些有特殊含义的字符,如\n,\t。
2;输出列表
就是需要输出的一些数据,也可以是表达式,如果在函数中需要输出多个变量或表达式,则要用逗号隔开.
一些特殊字符的输出:
单引号,双引号,和反斜杠的输出在前面加转义字符”\”
如:”\’” , “\”” , “\\”
%的输出用两个连在一起的%%,即printf(“%%”);

常用的格式说明如下:
格式字符
d 以十进制形式输出带符号整数
o 以八进制形式输出无符号整数
x 以十六进制形式输出无符号整数(
u 以十进制形式输出无符号整数
f 以小数形式输出单精度实数
lf以小数形式输出双精度实数
e 以指数形式输出单、双精度实数
c 输出单个字符
s 输出字符串

精度

精度格式符以“.”开头,后跟十进制整数。意义是:如果输出数字,则表示小数的位数;如果输出的是字符, 则表示输出字符的个数;若实际位数大于所定义的精度数,则截去超过的部分。

标志格式字符

- 结果左对齐,右边填空格

+ 输出符号(正号或负号)空格输出值为正时冠以空格,为负时冠以负号

例如:

double c=24212345.24232;

printf(“%20.4”); 表示输出精确到小数点后4位,输出占20位。 scanf:

scanf以空格或者以自己定义的符号区分不同的数据,且他会自己去掉输入的空格,以回车表示输入结束。

说一下scanf一个特别好用的地方,就是可以滤去一些不想要的东西。 举例说明如下:

比如输入为日期 yyyy-mm-dd,就可以这样写:

int year,moth,day;

scanf(“%d-%d-%d”,&year,&moth,&day);

再比如:

scanf("%3d %*3d %2d",&m,&n); 输入113 118 69回车(系统将113赋予m,将69赋予n,因为*号表示跳过它相应的数据所以118不赋予任何变量)

puts()用的不多,且基本都能用printf()代替,就是把括号里面用引号包围的东西全部输出到显示器。

gets()是从输入流中获取一行字符串放入字符数组中:

char in[100];

gets(in);

能进行字符,字符串输入的有:

getchar(), scanf(“%c”); scanf(“%s”), gets()

其中getchar() 和 scanf(“%c”)的功能是一样的。

需要注意的是,这两个函数读入的是输入缓冲区中当前位置的字符,

比如:

scanf(“%d”,&n);

c = getchar();

假设输入 67enter,则第一个scanf读入一个整数67后,当前输入流的位置是67之后,即指向回车符,所以第二个getchar()读入的就是一个回车符了,即 c = ‘\n’。

第2/5页

同样,gets()也是从输入缓冲区当前位置读入一行字符串。

比如:

scanf(“%d”,&n);

gets(str);

此时读入字符数组中的字符串就是“\n” 了

所以通常在用scanf读入一个非字符串的类型之后,如果要读入字符,或字符数组,都用一个额外的getchar()把回车符读掉,若后面跟的不止一个回车符,可能还有多余的空格的话,就用gets()读掉。

和以上不同的是,scanf(“%s”) 读入的时候是会忽略掉空格,回车和制表符的。并且以空格,回车和制表符作为字符串结束的标志。

C++输入输出总结

C++的一些输入方式包括:cin<<,cin.get(),cin.getline()。分别介绍如下: Cin<<:

该操作符是根据后面变量的类型读取数据,遇到空格、tab键、enter键输入结束。但是它会丢弃使得输入结束的结束符。 Cin.get():

该函数有三种格式:无参,一参数,二参数

即cin.get(), cin.get(char ch), cin.get(array_name, Arsize) 读取字符的情况:

输入结束条件:Enter键

对结束符处理:不丢弃缓冲区中的Enter

cin.get() 与 cin.get(char ch)用于读取字符,他们的使用是相似的, 即:ch=cin.get() 与 cin.get(ch)是等价的。

读取字符串的情况:

cin.get(array_name, Arsize)是用来读取字符串的,可以接受空格字符,遇到Enter结束输入,按照长度(Arsize)读取字符, 会丢弃最后的Enter字符。但是如果输入的数据长度超过给出的范围。其会按给出的arsize进行取舍。

三.cin.getline()

cin.getline() 与 cin.get(array_name, Arsize)的读取方式差不多,以Enter结束,可以接受空格字符。按照长度(Arsize)读取字符, 会丢弃最后的Enter字符。

但是这两个函数是有区别的:

cin.get(array_name, Arsize)当输入的字符串超长时,不会引起cin函数的错误,后面的cin操作会继续执行,只是直接从缓冲区中取数据。但是

cin.getline()当输入超长时,会引起cin函数的错误,后面的cin操作将不再执行。例如:

第3/5页

【分析】与cin.get(array_name, Arsize)的例程比较会发现,这里的ch并没有读取缓冲区中的e,而是返回了-52,这里其实cin>>ch语句没有执行,是因为cin出错了!

4、输入时易出错的地方:

有下面一段程序:

运行结果:

分析:程序之所以执行错误,没让读入一个字符是因为:cin>>和cin.get()都是从键盘缓冲区中读入的,当用户输入100并按回车时,此时换行符会被存储在键

第4/5页

盘缓冲区中cin.get()读入的是换行符,所以就没有输入字符的机会。从而导致程序运行失败。

解决办法:

Cin的后面加上cin.ignore(n,c) 其中括号里的参数是可以选择的,n是一个整数c是一个字符。含义是该函数跳过n个字符或者直到遇到C为止。如果次函数没有参数的话,表示键盘缓冲区的一个字符。解决后的程序为:



C++ 的输入方式:

C++的基本的输出是用cout<<

他的作用是输出《后的信息到控制台。

其常见的格式化输出形式有:

1、dec:按十进制输出.

2、Hex:按十六进制输出。

3、Oct:按八进制输出。

4、Endl:换行。

5、 Setw(n):为每个输入数据指定宽度。其中浮点数的宽度包括小数点所占的位置、默认的输出为右对齐、字符串中的空格也属于有效的空格并占宽度。且此操作仅对与其相邻的一个输出项有效。

6、Setprecision():指定浮点数的输出精度,即输出的有效数字的个数,且采用四舍五入对小数进行取舍。精度的设置在他北从新设置以前一直有效。 另外也可以使用函数成员实现输出:

如设置域宽用cout.width(n);

设置精度用:cout.precision();

Cout 的函数成员setf用来设置状态标志:比如设置小数点的位数、左右对其等。 其于操作法setiosflags的功能相同。本回答被网友采纳
相似回答