11.19回顾

一,强制类型转换

二,printf

1.基本用法:

printf()的基本作用是将参数文本输出到屏幕,它名字里面的f代表format(格式化),表示可以定制输出文本的格式。

例:

printf()不会在行尾自动添加换行符,运行结束后,光标就停留在输出结束的地方,不会自动换行。

为了让光标移到下一行的开头,可以在输出文本的结尾,加上一个换行符 \n。

两个printf不能使他们分成两行;要主动加换行符。

加换行符后。

同理

printf()是在标准的头文件stdio.h定义的。使用这个函数之前,必须在源代码文件头部引入这个头文件。

当头文件缺失时会出现以下报错。

2.占位符:

printf()可以在输入文本中指定占位符。

所谓“占位符”,就是这个位置可以用其他值代入。

如上例实例中,there are %d apples\n是输出文本,里面的%d就是占位符,表示这个位置要用其他值来替换。

占位符的第一个字符一律为百分号‘%’,第二个字符表示占位符的类型,%d表示这里带入的值必须是一个整数。

printf()的第二个参数就是替换占位符的值,上面的例子是整数3替换%d。执行后的输出结果就是there are 3 apples。

常用的占位符除了%d,还有%s表示代入的是字符串。

输出文本里面可以使用多个占位符。

printf()参数与占位符是一一对应的关系,如果有n个占位符,printf()的参数就应该有n+1个。如果参数个数少于对应的占位符,printf()可能会输出内存中的任意值。

3.占位符举例:

%a:十六进制浮点数,字母输出为小写。

%A:十六进制浮点数,字母输出为大写。

%c:字符。

%d:十进制整数。(int)

%e:使用科学计数法的浮点数,指数部分的e为小写。

%E:使用科学计数法的浮点数,指数部分的E为大写。

%i:整数,基本等同于%d。

%f:小数(包含float类型和double类型)。

%g:6个有效数字的浮点数。整数部分一旦超过6位,就会自动转为科学计数法,指数部分的e小写。

%G:等同于%g,唯一区别是指数部分的E为大写。

%hd:十进制 short int 类型。

%ho:八进制 short int 类型。

%hx:十六进制 short int 类型。

%hu:unsigned short int 类型。

%Id:十进制 long int 类型。

%lo:八进制 iong int 类型。

%lx:十六进制 long int 类型。

%lu:unsigned long int 类型。

%lld:十进制 long long int 类型。

%llo:八进制 long long int 类型。

%llx:十六进制 long long int 类型。

%llu:unsigned long long int 类型。

%Le:科学计数法表示的 long double 类型浮点数。

%Lf:long double 类型浮点数。

%n:已输入的字符串数量。该占位符本身不输出,只将值存储在指定变量之中。

%o:八进制整数。

%p:指针。

%s:字符串。

%u:无符号数(unsigned int )。

%x:十六进制整数。

%zd:size_t 类型。

%%:输出一个百分号。

4.输出格式:

printf()可以定制占位符的输出格式。

4.1限定宽度:

以上示例中,%5表示这个占位符的宽度至少为五位,如果不满五位,对应的值前面会添加空格。

但当位数足够五位或超过五位时直接就按照原本样子输出,所输出的值不会改变。

如:

输出的值默认是右对齐,即输出内容前面会有空格;若要改成左对齐,在输出内容后面添加空格,可以在占位符的%的后面插入一个‘ - ’(负号)。

如:

对于小数,这个限定符会限制所有数字的最小显示宽度。

注:小数点后的数字默认打印六位。

4.2总是显示正负号:

默认情况下,printf()不显示‘ + ’号,只显示‘ - ’号,可以在占位符的%后面加上个‘ + ’。

例:

默认:

加符号:

%+d可以确保输出的数值,总是带有正负号。

4.3限定小数位数。

输出小数时,可以限定小数位数。如保留小数后两位时可以将占位符写成%.2f。

这种写法可以与限定宽度占位符结合使用。

最小宽度和小数位数这两个限定值,可以用 * 代替,通过printf()的参数传入。

4.4输出部分字符串

%s占位符用来输出字符串,默认是全部输出。如果只想输出开头部分,可以用%.[m]s指定输出的长度,其中 [m] 代表一个数字,表示所要输出长度。

5.scanf

给变量输入值可以使用scanf函数,如果需要将变量的值输出在屏幕上的时候可以使用printf函数。

& ---取地址操作符。

5.1基本用法

scanf()函数用于读取用户的键盘输入。

程序运行到这个语句是,会停下来,等待你的输入。

你输入数据,按下回车键后,scanf()就会处理用户的输出,将其存入变量。

它的原型定义在头文件stdio.h。

scanf("%d",&i);------scanf的语法和printf的类似

注意:

1>scanf_s函数是VS提供的函数,并非C语言提供的,如果使用scanf_s其他编译器可能不认识这个函数。

2>如果想在VS上使用scanf函数就在.c文件的第一行加上:#define _CRT_SECURE_NO_WARNINGS

3>scanf函数也可以读入多个变量。

4>scanf函数处理数值占位符时,会自动过滤空白字符,包括空格,制表符,换行符等。

scanf函数处理输入的原理时,用户的输入先放入缓存,等到按下回车键后,按照占位符对缓存进行解读。

5>由于scanf函数将字符串读入字符数组时,不会检测字符串是否超过了数组的长度,所以在储存字符串时,很可能会超过数组的边界导致报错。

5.2 scanf的返回值

scanf的返回值是一个整数,表示成功读取的变量个数。

如果没有读取任何项,或者匹配失败,则返回0,如果在成功读取任何数据之前,发生了读取错误或者遇到读取到文件结尾,则返回常量EOF。

在VS环境下按3次ctrl+z结束输入

如果一个数字都不输入,直接按三次输出读取错误时返回      

EOF=-1;

5.3scanf函数输入数值时要要按照格式一致的输出

输出与格式一致时可以正常输出

当没有按照格式输出时便不会被编译器输入编辑。正确的如下所示

6.占位符

scanf()常用的占位符和printf()的占位符基本一致。

%c:字符。

%d:整数。

%d:float类型浮点数。

%lf:double类型浮点数。

%Lf:long double类型浮点数。

%s:字符串。

%[ ]:在方括号中指定一组匹配的字符(eg:%[0-9]),遇到不在集合之中的字符,匹配将会停止。

以上占位符中除了%c以外,都会自动忽略起首的空白字符。

%c不忽略空白字符,总是返回当前第一个字符,无论该字符是否为空格。

其他 例%d:

若要强制跳过字符前的空白字符,可以写成scanf("  %c",&ch),即%c前加上一个空格,表示跳过零个或多个空白字符。

%s:

它不等同于字符串,其规则为从当前第一个非空白字符开始读起,直到遇见空白字符为止。

一般在用%s时,应指定读入字符串的最长长度,即写成%[m]s,其中的[m]是一个整数,表示读取字符串的最大长度,后面的字符将被丢弃。

7.赋值忽略符‘ * ’

只要把‘ * ’加在任何占位符的百分号后面,该占位符就不会返回值,解析后将会被丢弃。

未使用之前

使用*后

上面的示例中,%*c就是在占位符的百分号后面,加入了赋值忽略符 * ,表示这个占位符没有对应的变量,解读后不必返回。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值