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

✅作者简介:人工智能专业本科在读,喜欢计算机与编程,写博客记录自己的学习历程。
🍎个人主页:小嗷犬的博客
🍊个人信条:为天地立心,为生民立命,为往圣继绝学,为万世开太平。
🥭本文内容:C与C++的最常用输入输出方式对比
更多内容请见👇



C

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

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

占位符

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

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


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

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

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

C++

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

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++的输入输出更加便捷,语法也更易理解,成为程序员程序设计中优先考虑的输入输出方式。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小嗷犬

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值