✅作者简介:人工智能专业本科在读,喜欢计算机与编程,写博客记录自己的学习历程。
🍎个人主页:小嗷犬的博客
🍊个人信条:为天地立心,为生民立命,为往圣继绝学,为万世开太平。
🥭本文内容:C与C++的最常用输入输出方式对比
更多内容请见👇
1.C
1.1 scanf() 输入
scanf()
,格式化输入,C语言中最常用的输入函数,函数声明如下:
int scanf(const char *format, ...);
函数依赖 标准输入输出头文件stdio.h
,使用前要通过 预处理命令#include
引入头文件。函数的第一个参数
format
为包含占位符的C字符串,随后的参数为占位符对应类型变量的地址,通常与取地址符&
结合使用。输入的内容必须严格按照
format
规定的格式,即除占位符外,format
中的其他字符都要原原本本地输入。函数的返回值为
scanf
成功赋值的数据个数。
#include<stdio.h>
int main()
{
int a, b, c;
printf("请输入三个数字:");
scanf("A%dB%dC%d", &a, &b, &c);
//输入的格式必须严格按照scanf中的格式
//即输入:A整数B整数C整数 的形式
//正确输入后返回值为:3
printf("%d,%d,%d\n", a, b, c);
return 0;
}
1.2 printf() 输出
printf()
,格式化输出,C语言中最常用的输出函数,函数声明如下:
int printf(const char *format, ...)
函数依赖 标准输入输出头文件stdio.h
,使用前要通过 预处理命令#include
引入头文件。函数的第一个参数
format
为C字符串,随后的参数为占位符对应类型变量。函数会按照
format
格式将后面的参数填入占位符,然后输出到控制台。函数的返回值为
printf
实际控制输出的字符数。
#include<stdio.h>
int main()
{
int a = 0, b = 1, c = 2;
printf("我是%d一个可爱%d的格式鸭!%d\n", a, b, c);
//程序将输出:我是0一个可爱1的格式鸭!2
//正确输出后返回值为:26(汉字与中文符号占2个,'\n'占1个)
return 0;
}
1.3 占位符
占位符是一种有特定作用的符号,用于在格式化字符串中占住一个固定的位置,之后填充。占位符分为输入占位符和输出占位符。
输入占位符的一般格式为:%[*][输入数据宽度][长度]类型
其中有方括号[]
的项为非必选项输入占位符中
[*]
表示该输入项读入后不赋予相应的变量,即跳过该输入值。
#include<stdio.h>
int main()
{
int a, b;
printf("请输入两个数字:");
scanf("%d %*d %d", &a, &b);
printf("%d,%d\n", a, b);
//如果输入:1 2 3
//将会输出:1,3
return 0;
}
常用输入类型字符见下表:
类型字符 | 功能 | 对应数据类型 |
---|---|---|
d | 输入十进制整数 | int |
lld | 输入十进制长整数 | long long |
o | 输入八进制整数 | int |
x | 输入十六进制整数 | int |
u | 输入无符号十进制整数 | unsigned int |
llu | 输入无符号十进制长整数 | unsigned long long int |
f或e | 输入浮点数(用小数形式或指数形式) | float |
lf | 输入双精度浮点数 | double |
c | 输入单个字符 | char |
s | 输入字符串 | char* |
代码实例:
#include<stdio.h>
int main()
{
int a;
scanf("%4d", &a);
//程序支持读入一个4位以内的非负整数或一个3位以内的负整数
printf("%d", a);
return 0;
}
输出占位符的一般格式为:%[标志][输出最小宽度][.精度][长度]类型
其中有方括号[]
的项为非必选项输出占位符中
[.精度]
表示如果输出数字,则表示小数的位数;如果输出的是字符,则表示输出字符的个数常用输出类型字符见下表:
类型字符 | 功能 | 对应数据类型 |
---|---|---|
d | 以十进制形式输出整数 | int |
lld | 以十进制形式输出长整数 | long long |
o | 以八进制形式输出无符号整数(不输出前缀0) | int |
x | 以十六进制形式输出无符号整数(不输出前缀0x) | int |
u | 以十进制形式输出无符号整数 | unsigned int |
llu | 以十进制形式输出无符号长整数 | unsigned long long int |
f | 以小数形式输出单、双精度实数 | float, double |
e | 以指数形式输出单、双精度实数 | float, double |
g | 以%f%e中较短的输出宽度输出单、双精度实数 | float, double |
c | 输出单个字符 | char |
s | 输出字符串 | char* |
常用输出标志字符见下表:
标志字符 | 功能 |
---|---|
- | 结果左对齐,右边填空格。 |
+ | 输出符号(正号或负号)。 |
空格 | 输出值为正时冠以空格,为负时冠以负号。 |
|输出非十进制数时冠以前缀(0或0x);输出浮点数时在小数部分为0时省略小数点。
代码实例:
#include<stdio.h>
int main()
{
float a = 3.1415926;
printf("%.2f", a);
//程序会输出:3.14
return 0;
}
2.C++
2.1 cin 输入
cin
,标准输入流,是iostream
类的一个实例,通常与流提取运算符>>
结合使用。
cin
依赖 头文件iostream
,使用前要通过 预处理命令#include
引入头文件。
cin
位于命名空间std
下,使用前通常使用命名空间std
,即:using namespace std;
C++ 编译器会根据要输入值的数据类型,选择合适的流提取运算符来提取值,并把它存储在给定的变量中。
因此
cin
不需要记忆C语言中繁多的占位符。流提取运算符
>>
在一个语句中可以多次使用。
//代码:
cin >> a >> b;
//等价于:
cin >> a;
cin >> b;
代码实例:
#include <iostream>
using namespace std;
int main() {
int a, b;
cin >> a >> b;
cout << a << "," << b << endl;
//如果输入:1 2
//程序会输出:1,2
return 0;
}
2.2 cout 输出
cout
,标准输出流,是iostream
类的一个实例,通常与流插入运算符<<
结合使用。
cout
依赖 头文件iostream
,使用前要通过 预处理命令#include
引入头文件。
cout
位于命名空间std
下,使用前通常使用命名空间std
,即:using namespace std;
C++ 编译器会根据要输出变量的数据类型,选择合适的流插入运算符来显示值。
流插入运算符<<
被重载来输出内置类型(整型、浮点型、double 型、字符串和指针)的数据项。因此
cout
也不需要记忆C语言中繁多的占位符。流插入运算符
<<
在一个语句中可以多次使用。
//代码:
cout << a << b << endl;
//等价于:
cout << a;
cout << b;
cout << endl;
endl
表示换行符。代码实例:
#include <iostream>
using namespace std;
int main() {
int a = 2;
string s = "最小的素数:";
cout << s << a << endl;
//程序会输出:最小的素数:2
return 0;
}
综上所述,C++的输入输出能够帮程序员更好地把注意力集中在程序设计上,而不是纠结输入输出该使用何种占位符,在一般的输入输出情况下,C++的输入输出更加便捷,语法也更易理解,成为程序员程序设计中优先考虑的输入输出方式。