一.输入输出的概念
输入 ---> 计算机 ---> 输出
键盘,鼠标等 [ 内存 ] 屏幕等
输入设备输入数据存放在计算机的内存之中,再由输出设备输出信息。
二.输入输出功能的实现:
(1)C语言本身是并不提供输入输出功能的。
使用的是C语言库中的“标准输入输出”函数。
(2)C语言函数库提供的输入输出函数
getchar / putchar //操作一个字符
gets / putchar //操作一个字符串
scanf / printf //格式化字符
(3)需要加上<stdio.h>头文件
三.函数
getchar/putchar
getchar
int getchar(void); //函数原型
功能:
从键盘获取一个字符
参数:
void --- 表示为空 //表示使用时不需要给实参
返回值:
返回值 表示 获取到的字符的 ASCII码值
eg:
int ret;
ret = getchar(); //表示获取到getchar读取的字符的ASCII的值
putchar
int putchar(int c);
功能:
输出一个字符
参数:
int c --- 表示要出的的字符
返回值:
成功 输出了的字符的ASCII码值
失败 -1
eg:
putchar('a');
scanf/printf
scanf
格式:
scanf("格式控制字符串",地址列表)
(1).格式控制字符串
scanf("a = %d");
a.普通字符 --- 原样输入
b.占位符 --- 将从键盘输入的数据 转换成指定的格式
整型
%d --- 转换为 有符号 十进制形式
%u --- 转换为 无符号 十进制形式
%o --- 转换为 八进制形式
%x --- 转换为 十六进制形式
%X --- 转换为 十六进制形式 a b c d e f以大写形式输出
0X //x也会是大写
+123
-123
浮点型
%f --- 转换为 十进制形式的小数,输出时默认保留6位小数,不足6位 补0
%e --- 转换为 科学计数法的形式
%E 指数形式中e 变成 大写 E
%g --- 以 一种 更简洁的方式输出,同时不会输出无意义的0
字符型
%c --- 转换为字符形式输出
%s --- 转换为字符串形式输出
(2).地址列表
int a;
scanf("a = %d",&a);
辅助控制符
%d
m //数据宽度 ---输入宽度
l //
%lf //输入的时候 ,这里要做到精确匹配
%f --- float
%lf --- double
%Lf --- long double
%ld --- long
%lld --- long long
注意:
1. scanf 格式控制字符串中尽量不出现 普通字符,一般只写占位符
2. scanf 的地址列表中,一定是有效的地址
3. scanf 输入结束的条件(匹配结束的条件)
eg.%d
[12a3]
a.遇到非法字符 ' a '匹配结束
b.遇到空白符匹配结束
空白符 (空格 回车 tab)
[1 2 3]
c.超过指定的宽度结束
4. scanf的格式控制字符串中,如果出现空白符 ,表示匹配任意多个空白符
%*c 表示匹配一个数据项 但是并不把这个数据给到任何一个变量中
printf()
eg:
printf("a = %d\n",10);
//
a = 10
int printf(const char *format, ...);
... //表示 可变参数
printf("hello world!\n");
printf("a = %d\n",a);
printf("a = %d b = %f c = %c\n",a,b,c);
printf("格式控制字符串",输出参数列表);
printf("a = %d\n",a);
(1).格式控制字符串
a.普通字符 --- 原样输出
b.占位符 --- 匹配后面的输出参数的
%d 将后面的输出参数 转换为 有符号十进制 形式输出
整型
%d --- 转换为 有符号 十进制形式
%u --- 转换为 无符号 十进制形式
%o --- 转换为 八进制形式
%x --- 转换为 十六进制形式
%X --- 转换为 十六进制形式 a b c d e f以大写形式输出
0X //x也会是大写
浮点型
%f --- 转换为 十进制形式的小数,输出时默认保留6位小数,不足6位 补0
%e --- 转换为 科学计数法的形式
%E 指数形式中e 变成 大写 E
%g --- 以 一种 更简洁的方式输出,同时不会输出无意义的0
字符型
%c --- 转换为字符形式输出
%s --- 转换为字符串形式输出
占位符
%[辅助控制符]d
(2) 辅助控制符:
# ---- %#x //打印出8进制 或 16进制的前缀
%#o
m ---- 数字 表示要输出的数据的宽度
如果数据本身的宽度 > m 此时按照实际宽度输出
如果数据本身的宽度 < m 此时按照m宽度输出,空出来的位置 填空格
默认右对齐
-m ---- 按指定宽度输出 ,左对齐 (负号表示左对齐)
0m ---- 多出来的位置 可以填充0
.n ---- n数字
%f //%.2f //表示保留2位小数
%e
%s //表示 保留前n个字符
l ---- long
ll ---- long long //整型
h ---- half
hh ---- half half