scanf(),格式化输入,C语言中最常用的输入函数,函数声明如下:
int scanf(const char *format, ...);
函数依赖 标准输入输出头文件 stdio.h,使用前要通过 预处理命令 #include 引入头文件。
函数的第一个参数 format 为包含占位符的C字符串,随后的参数为占位符对应类型变量的地址,通常与取地址符&结合使用。
输入的内容必须严格按照 format 规定的格式,即除占位符外,format中的其他字符都要原原本本地输入。
函数的返回值为scanf成功赋值的数据个数。
#include
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;
}
printf(),格式化输出,C语言中最常用的输出函数,函数声明如下:
int printf(const char *format, ...)
函数依赖 标准输入输出头文件 stdio.h,使用前要通过 预处理命令 #include 引入头文件。
函数的第一个参数 format 为C字符串,随后的参数为占位符对应类型变量。
函数会按照 format 格式将后面的参数填入占位符,然后输出到控制台。
函数的返回值为printf实际控制输出的字符数。
#include
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;
}
占位符是一种有特定作用的符号,用于在格式化字符串中占住一个固定的位置,之后填充。
占位符分为输入占位符和输出占位符。
输入占位符的一般格式为:%[*][输入数据宽度][长度]类型
其中有方括号[]的项为非必选项
输入占位符中[*]表示该输入项读入后不赋予相应的变量,即跳过该输入值。
#include
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
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
int main()
{
float a = 3.1415926;
printf("%.2f", a);
//程序会输出:3.14
return 0;
}
cin,标准输入流,是 iostream 类的一个实例,通常与流提取运算符 >> 结合使用。
cin 依赖 头文件 iostream,使用前要通过 预处理命令 #include 引入头文件。
cin 位于命名空间std下,使用前通常使用命名空间std,即:
using namespace std;
C++ 编译器会根据要输入值的数据类型,选择合适的流提取运算符来提取值,并把它存储在给定的变量中。
因此cin不需要记忆C语言中繁多的占位符。
流提取运算符 >> 在一个语句中可以多次使用。
//代码:
cin >> a >> b;
//等价于:
cin >> a;
cin >> b;
代码实例:
#include
using namespace std;
int main() {
int a, b;
cin >> a >> b;
cout << a << "," << b << endl;
//如果输入:1 2
//程序会输出:1,2
return 0;
}
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
using namespace std;
int main() {
int a = 2;
string s = "最小的素数:";
cout << s << a << endl;
//程序会输出:最小的素数:2
return 0;
}
综上所述,C++的输入输出能够帮程序员更好地把注意力集中在程序设计上,而不是纠结输入输出该使用何种占位符,在一般的输入输出情况下,C++的输入输出更加便捷,语法也更易理解,成为程序员程序设计中优先考虑的输入输出方式。