C与C++的最常用输入输出方式对比

C与C++的最常用输入输出函数对比

  • 1.C
    • 1.1 scanf() 输入
    • 1.2 printf() 输出
    • 1.3 占位符
  • 2.C++
    • 2.1 cin 输入
    • 2.2 cout 输出

1.C

1.1 scanf() 输入

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; 
}

1.2 printf() 输出

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; 
}

1.3 占位符

占位符是一种有特定作用的符号,用于在格式化字符串中占住一个固定的位置,之后填充。

占位符分为输入占位符和输出占位符。


输入占位符的一般格式为:%[*][输入数据宽度][长度]类型
其中有方括号[]的项为非必选项

输入占位符中[*]表示该输入项读入后不赋予相应的变量,即跳过该输入值。

#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; 
}

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 
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 
using namespace std;

int main() {
	int a = 2;
	string s = "最小的素数:";

	cout << s << a << endl;
	//程序会输出:最小的素数:2
	return 0;
}

综上所述,C++的输入输出能够帮程序员更好地把注意力集中在程序设计上,而不是纠结输入输出该使用何种占位符,在一般的输入输出情况下,C++的输入输出更加便捷,语法也更易理解,成为程序员程序设计中优先考虑的输入输出方式。

你可能感兴趣的:(C/C++基础入门,c++,c语言,开发语言)