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

简介: C与C++的最常用输入输出方式对比,IO,scanf,printf,cin,cout,占位符。使用方法,函数声明,代码实例。区别,优缺点。

✅作者简介:人工智能专业本科在读,喜欢计算机与编程,写博客记录自己的学习历程。
🍎个人主页:小嗷犬的博客
🍊个人信条:为天地立心,为生民立命,为往圣继绝学,为万世开太平。
🥭本文内容: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++的输入输出更加便捷,语法也更易理解,成为程序员程序设计中优先考虑的输入输出方式。
目录
相关文章
|
C++ 计算机视觉 数据格式
C/C++主调函数从被调函数中获取(各种类型)数据内容方式的梳理归纳
C/C++主调函数从被调函数中获取(各种类型)数据内容方式的梳理归纳
229 1
C/C++主调函数从被调函数中获取(各种类型)数据内容方式的梳理归纳
|
API C语言 C++
C++文件操作的5种方式
C++文件操作的5种方式
159 1
|
编译器 C++
C++函数参数传递的三种方式
C++函数参数传递的三种方式
201 0
|
存储 编译器 文件存储
C++语言中多文件组合方式之经典
C++语言中多文件组合方式之经典
239 0
|
C++
C++常量定义的两种方式
# C++常量 作用:用于记录程序中不可更改的数据 C++常量定义的两种方式 1.#define 宏常量:#define 常量名 常量值 ​ 通常在文件上方定义,表示一个常量 2. const修饰的变量:const 数据类型 常量名 = 常量值 ​ 通常在变量定义前加关键字const,修饰该变量为常量,不可修改 示例:
230 0
|
存储 人工智能 算法
C++如何处理图的存储方式
C++如何处理图的存储方式
249 0
C++如何处理图的存储方式
|
Java 机器人 物联网
【C++初阶:内存管理】C/C++内存分布及管理方式 | new/delete实现原理及operator new和operator delete函数 下
【C++初阶:内存管理】C/C++内存分布及管理方式 | new/delete实现原理及operator new和operator delete函数
187 0
【C++初阶:内存管理】C/C++内存分布及管理方式 | new/delete实现原理及operator new和operator delete函数 下
|
存储 Java Linux
【C++初阶:内存管理】C/C++内存分布及管理方式 | new/delete实现原理及operator new和operator delete函数 上
【C++初阶:内存管理】C/C++内存分布及管理方式 | new/delete实现原理及operator new和operator delete函数
153 0
【C++初阶:内存管理】C/C++内存分布及管理方式 | new/delete实现原理及operator new和operator delete函数 上
|
编译器 C++ 容器
C++中多用引用传递方式替换值传递方式
C++中多用引用传递方式替换值传递方式
496 0