c和c++中读取数据的方式总结

目录


 

最近在学习C和C++,除了在写OS的时候用到外,写算法的时候也会用到,整理记录C和C++读取数据的各种方式。
文章较长,总结稍微详细了一点。

c输出printf()

在 stdio.h 中包含最经典的输出函数 printf

#include <stdio.h>      // 执行 printf() 函数需要该库int main(){    printf("hello weiwei");  //显示引号中的内容    return 0;}

格式化输出,在 printf中格式化输出的格式:
1)类型

格式字符含义
d以十进制形式输出带符号整数(正数不输出符号)
o以八进制形式输出无符号整数(不输出前缀0)
x,X以十六进制形式输出无符号整数(不输出前缀Ox)
u以十进制形式输出无符号整数
f以小数形式输出单、双精度实数
e,E以指数形式输出单、双精度实数
g,G以%f或%e中较短的输出宽度输出单、双精度实数
c输出单个字符
s输出字符串
p,P%p是一个新的格式控制符,它表示以十六进制的形式(带小写的前缀)输出数据的地址。如果写作%P,那么十六进制的前缀也将变成大写形式。

2)标志

标志含义
-结果左对齐
+输出符号(正负号)
空格输出值为正时冠以空格,为负时冠以负号
#对c、s、d、u类无影响;
对o类,在输出时加前缀o;
对x类,在输出时加前缀0x;
对e、g、f 类当结果有小数时才给出小数点。

3) 输出最小宽度
用十进制整数来表示输出的最少位数。若实际位数多于定义的宽度,则按实际位数输出,若实际位数少于定义的宽度则补以空格或0。
4) 精度
精度格式符以“.”开头,后跟十进制整数。本项的意义是:如果输出数字,则表示小数的位数;如果输出的是字符,则表示输出字符的个数;若实际位数大于所定义的精度数,则截去超过的部分。
5) 长度
长度格式符为h、l两种,h表示按短整型量输出,l表示按长整型量输出。
我们通过一个实例来掌握用法:

#include<cstdio>int main(){    int a=15;    float b=123.1234567;    double c=12345678.1234567;    chard='p';    printf("a=%d\n", a);    printf("a(%%d)=%d, a(%%5d)=%5d, a(%%o)=%o, a(%%x)=%x\n\n",a,a,a,a);  // %% 可以输出 %    printf("b=%f\n", b);    printf("b(%%f)=%f, b(%%lf)=%lf, b(%%5.4lf)=%5.4lf, b(%%e)=%e\n\n",b,b,b,b);    printf("c=%f\n", c);    printf("c(%%lf)=%lf, c(%%f)=%f, c(%%8.4lf)=%8.4lf\n\n",c,c,c);    printf("d=%c\n", d);    printf("d(%%c)=%c, d(%%8c)=%8c\n",d,d);    printf("&a=%p, &b=%p, &c=%p\n", &a, &b, &c);    // 输出地址        return 0;}

  • 以四种格式输出整型变量a的值,其中“%5d ”要求输出宽度为5,而a值为15只有两位故补三个空格。
  • 以四种格式输出实型量b的值。其中“%f”和“%lf ”格式的输出相同,说明“l”符对“f”类型无影响。“%5.4lf”指定输出宽度为5,精度为4,由于实际长度超过5故应该按实际位数输出,小数位数超过4位部分被截去。
  • 输出双精度实数,“%8.4lf ”由于指定精度为4位故截去了超过4位的部分。
  • 输出字符量d,其中“%8c ”指定输出宽度为8故在输出字符p之前补加7个空格

输入scanf

scanf() 应该是我们所有人接触C语言的第一个输入函数了,输入同样需要指定输入的格式化类型和保存该变量的地址。

#include <cstdio>int main(){    int a, b, c;    scanf("%d %d", &a, &b);    printf("a+b=%d\n", a+b);    scanf("%d   %d", &a, &b);    printf("a+b=%d\n", a+b);    scanf("%d, %d, %d", &a, &b, &c);    printf("a+b+c=%d\n", a+b+c);       scanf("%d is bigger than %d", &a, &b);    printf("a-b=%d\n", a-b);      char letter;    int age;    char url[30];   // 字符串的定义    float price;      scanf("%c", &letter);    scanf("%d", &age);    scanf("%s", url); //可以加&也可以不加&    scanf("%f", &price);         return 0;}

scanf 函数是一种宽松的输入函数,你需要按照你指定的格式来输入,这个时候就可以按照你输入的格式来读取到响应的数据。
从本质上讲,我们从键盘输入的数据并没有直接交给 scanf(),而是放入了缓冲区中,直到我们按下回车键,scanf() 才到缓冲区中读取数据。如果缓冲区中的数据符合 scanf() 的要求,那么就读取结束;如果不符合要求,那么就继续等待用户输入,或者干脆读取失败。

格式控制符说明
%c读取一个单一的字符
%hd、%d、%ld读取一个十进制整数,并分别赋值给 short、int、long 类型
%ho、%o、%lo读取一个八进制整数(可带前缀也可不带),并分别赋值给 short、int、long 类型
%hx、%x、%lx读取一个十六进制整数(可带前缀也可不带),并分别赋值给 short、int、long 类型
%hu、%u、%lu读取一个无符号整数,并分别赋值给 unsigned short、unsigned int、unsigned long 类型
%f、%lf读取一个十进制形式的小数,并分别赋值给 float、double 类型
%e、%le读取一个指数形式的小数,并分别赋值给 float、double 类型
%g、%lg既可以读取一个十进制形式的小数,也可以读取一个指数形式的小数,并分别赋值给 float、double 类型
%s读取一个字符串(以空白符为结束)getchar(), putchar()

int getchar(void) 函数从屏幕读取下一个可用的字符,并把它返回为一个整数。这个函数在同一个时间内只会读取一个单一的字符。您可以在循环内使用这个方法,以便从屏幕上读取多个字符。
int putchar(int c) 函数把字符输出到屏幕上,并返回相同的字符。这个函数在同一个时间内只会输出一个单一的字符。您可以在循环内使用这个方法,以便在屏幕上输出多个字符。

#include <stdio.h> int main( ){   int c;    printf"Enter a value :");   c = getchar( );    printf"\nYou entered: ");   putchar( c );   printf"\n");   return 0;}gets(), puts()

char *gets(char *s) 函数从 stdin 读取一行到 s 所指向的缓冲区,直到一个终止符或 EOF。
int puts(const char *s) 函数把字符串 s 和一个尾随的换行符写入到 stdout

#include <stdio.h> int main( ){   char str[100];    printf"Enter a value :");   gets( str );    printf"\nYou entered: ");   puts( str );   return 0;}

由于 gets 函数具有安全问题,现在已经不推荐使用。

c++输入cin()

使用cin输入时,程序将输入视为一系列字节。每个字节都被解释为字符编码。不管数据类型是什么,输入一开始都是字符数据,然后cin对象负责将数据转换成其他类型。

string name;std::cin>>name;std::cout<<name;

当你输入Michael Jackon时,通运行程序你会发现name只存储了Michael,这是为什么呢?
原来是 cin使用空白(空格,制表符和换行符)来确定字符串的结束位置。
在读取字符数组时,cin将只会读取第一个单词,cin将该字符串放到数组中,并自动添加空字符。Michael Jackon 之间的空格被当作结束符了,而Jackon被继续留在输入队列中,直到下一次读取输入。

getline()

getline() 函数用于读取整行,通过回车键来确定输入的结尾。
假如你还是要读取MIchael Jackon

String name;getline(cin,name);std::cout<<name:

或者你可以用char数组

char name[50];std::cin.getline(name,50);std::cout<<name;

这是你就会发现读取的是Michael Jackon了。
getline虽然通过读取换行符来读取结尾,但是它并不保存换行符,保存字符串是,他会用空字符来代替换行符。
getline读取完一行时,会从下一行开始读,也就是说我们可以跳过某一行。
假设我们读取文本文件时,不读取某一行,我们可以这样做:

string str;getline(cin,str);

这样便跳过这一行了。

get()

iostream 中有一个名为get()的变体,他的工作方式和getline()类似。他们接受参数相同,解释参数的方式也相同,并且都读取到行尾。使用get()读取到行尾时不丢弃换行符,而是将它留在输入队列中:

cin.get(name,50);cin.get(dessert,50);

假设读取了一个字符串,再读取时,读取到的便是换行符了,get()便认为已经到达行尾了,不再继续读取。
怎么解决呢?
我们可以在两次读取之间加一个cin.get();用来读取下一个字符,即使是换行符。

cin.get(name,50);cin.get();cin.get(dessert,50)输出cout

预定义的对象 cout 是 iostream 类的一个实例。cout 对象"连接"到标准输出设备,通常是显示屏。cout 是与流插入运算符 << 结合使用的。我们使用 cout 来输出各种类型的数据,而不需要考虑输出数据的类型,使用 endl来换行。

char str[] = "Hello C++";cout << "Value of str is : " << str << endl;


本文对C和C++中常用的输入输出命令做了简单总结,但是暂时还没有涉及到文件的输入输出,之后抽空总结一下C和C++中文件的输入输出。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值