一,强制类型转换
二,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就是在占位符的百分号后面,加入了赋值忽略符 * ,表示这个占位符没有对应的变量,解读后不必返回。