printf 和 scanf 并没有这么简单

                    Hi~!这里是奋斗的小羊,很荣幸各位能阅读我的文章,诚请评论指点,关注+收藏,欢迎欢迎~~     

                        💥个人主页小羊在奋斗

                        💥所属专栏C语言   

        本系列文章为个人学习笔记,在这里撰写成文一为巩固知识,二为同样是初学者的学友展示一些我的学习过程及心得。文笔、排版拙劣,望见谅。 

                    一、printf 和 scanf 介绍

                                        1.printf函数

                                        2.scanf函数

        文章写的比较细,诚请耐心看完。

 一、printf 和 scanf 介绍

1.printf函数

        1.1基本用法

        printf 函数我们在前几篇文章已经浅显的了解过,在本文中我们来全面的探讨一下它的具体用法和作用。printf()的作用是将参数文本输出到屏幕。它名字里面的 f 代表 format(格式化),代表可以定制输出文本的格式。

        可以看到上面的命令会在屏幕上输出一行文字 HelloWorld 。

        printf()不会在行尾自动添加换行符,运行结束后,光标就停留在输出结束的地方,不会自动换行。为了让光标移到下一行的开头,可以在输出文本的结尾,添加一个换行符 \n 。这个转义字符我们也已了解过:

        当然在文本内换行也是可行的:

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

        1.2占位符

        printf()可以在输出文本中指定占位符,所谓 “占位符” 就是这个位置可以用其他值代入。

        上面示例中,There are %d apples\n 是输出文本,里面的%d就是占位符,表示这个位置要用其他值来替换。占位符的第一个字符一律为百分号%,第二个字符表示占位符的类型,%d表示这里代入的值必须是一个整数。printf()的第二个参数就是替换占位符的值,上面的例子是整数3替换%d,执行后的输出结果就是There are 3 apples。

        当然,除了%d外,我们上篇文章(C语言基础)还提及到了%s(字符串占位符)、%c(字符占位符)、%f(单精度实型占位符)、%lf(双精度实型占位符)、%u(无符号整型占位符),它们的用法都是一样的。

        输出文本里不一定只有一个占位符,可以有多个,也可以混用。值得注意的是,printf()函数参数与占位符是一一对应关系,如果有n个占位符,printf()的参数就应该有n+1个。如果参数个数少于对应的占位符,printf()可能会输出内存中的任意值。

        可以看到,这里printf()输出了一个任意值字符型 ‘p’ 。

        1.3输出格式

        printf()可以定制占位符的输出格式,亦允许限制占位符的最小宽度。

        可以看到,我们设定打印第一个整型123的占位符最小宽度为2,printf()给我们顶格打印了123;设定打印第二个整型123的占位符最小宽度为5,printf()给我们空了两格再打印了123。这里相信友友们已经很清楚的明白了printf()允许限定占位符的最小宽度这句话。

       上面示例中,%5d 表示这个占位符的宽度至少为5位,如果不满5位,对应的值的前面会添加空格。输出的值默认是右对齐,即输出内容前面会有空格;如果希望改成左对齐,在输出内容后面添加空格,可以在占位符的%的后面插入一个 - 号:

        限定符对小数同样有用:

        如果我们想让打印出来的数总是显示正负号,默认情况下,printf()不对正数显示+号,只对负数显示-号。如果想让正数也输出+号,可以在占位符的%后面加一个+。

        printf()不止可以限制占位符的最小宽度,还可以限制小数的位数。

        输出小数时,有时希望限定小数的位数,比如希望小数点后面只保留两位,占位符就可以写成%.2f。当然这种写法也可以与限定宽度占位符结合使用:

        而且我们也可以看到,它是会四舍五入的。

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

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

2.scanf函数

        我们在VS上使用 scanf 这个函数的时候一般都会报错,具体解决办法可参考我的相关文章。

        关于在VS上使用scanf函数报错的解决办法

        点击上方文字即可跳转到相关文章。

        2.1基本用法

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

        程序运行到这个语句的时候,会停下来,等待用户从键盘输入。用户输入数据,按下回车键后,scanf()就会处理用户的输入,将其存入变量。它的原型定义在头文件 stdio.h 。它的用法跟printf()类似。

        当我们有了变量,我们需要给变量输入值的时候就可以使用 scanf 函数,如果需要将变量的值输出到屏幕上的时候可以使用 printf 函数,下面看一个例子:

        我们在用scanf()函数的时候,其参数变量的前面一定要加上取地址符(&)(指针变量除外),因为scanf()传递的不是值,而是地址,即将变量的地址指向用户输入的值。我把这个过程理解为我们用取地址符向内存申请了一块空间,然后从键盘输入一个值存放到这个空间里,只有在申请了这个空间的前提下我们输入的值才能有地方可以放,整个过程就像初始化变量一样,同样都是先申请在给值。

       它的第一个参数是一个格式字符串,里面会放置占位符(与printf()的占位符基本一致),告诉编译器如何解读用户的输入,需要提取的数据是什么类型。这是因为C语言的数据都是有类型的,scanf()必须提前知道用户输入的数据类型,才能处理数据。它的其余参数就是存放用户输入的变量,格式字符串里面有多少个占位符,就有多少个变量。

        下面是一次从键盘输入多个变量的例子:

        上面示例中,格式字符 %d %c %f %lf 表示用户输入整数、字符、单精度浮点数、双精度浮点数,比如 1 b 3.3 4.4 ,这四个值依次放入a b c d 四个变量。

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

        所以,用户输入的数据之间,有一个或多个空格不影响 scanf()解读数据。另外,用户使用回车键,将输入分成几行,也不影响解读。

        上面示例中,我随意空格、换行输入,得到的结果是一致的。

        scanf()处理用户输入的原理是,用户的输入先放入输入缓冲区,等到按下回车键后,按照占位符对缓存进行解读。解读用户输入时,会从上一次解读遗留的第一个字符开始,直到读完缓存,或者遇到第一个不符合条件的字符为止。我们来通过下面这个例子深刻理解:

        上面这个示例中scanf()是怎么处理我们输入的      -23.45e4# 0(前面有若干空格)这个值的呢?

        首先,第一个scanf()读取数据,自动略过若干空格后,来到 -23 跟前,因为 -23 后面有小数点,所以只将 -23 存入整型变量 a 中;然后,第二个scanf()读取数据,因为 0.45*10^4 后面的 # 时字符,所以只将 0.45*10^4 这个值存入浮点型变量 b 中。到此,整个程序结束。学友们在细品一下图片上面那段话,是不是理解更深刻了呢?

        还有一个很值得注意的点,就是我们在输入数据的时候,一定要注意输入数据的格式必须要与scanf()函数第一个参数中的格式保持一致,来看几个示例:

        2.2scanf的返回值

        scanf()的返回值是一个整数,表示成功读取的变量的个数。如果没有读取任何项,或者匹配失败,则返回 0。

        如果在成功读取任何数据之前,发生了读取错误或者遇到读取到文件结尾,则返回常量 EOF(-1)。

        2.3占位符

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

        在scanf()常用占位符中有一个特殊的 %[ ]:在方括号中指定一组匹配的字符(比如%[0-9]),遇到不在集合之中的字符,匹配将会停止。

        所有的占位符中,除了 %c 以外,都会自动忽略起首的空白字符。%c 不能忽略空白字符,总是返回当前第一个字符,无论该字符是否为空格。空格也是一个字符。

        不知道我上面举的例子表达的清不清楚呢?

        第二张图片中scanf()把字符 a 前面最开始的空格读取放入了变量 ch 中,所以我们打印出来的 x 和 y 中间是一个空格。

        如果要强制跳过字符前的空白字符,可以写成 scanf(“ %c”,&ch),即 %c 前加上一个空格,表示跳过零个或多个空白字符。我们用上面的例子来验证一下:

        可以看到,无论我们在字符 a 的前面空了多少个空格,scanf()都能把字符 a 读取放入变量ch 中,最终在 x 和 y 中间打印出来。

        还要特别说一下占位符 %s ,它其实也挺矫情的。它不能简单的等同于字符串。它的规则是,从当前第一个非空白字符开始读起,直到遇到空白字符(即空格、换行符、制表符等)为止。因为 %s 不会包含空白字符,所以无法用来读取多个字符,除非多个 %s 一起使用。这也意味着,scanf()不适合读取可能包含空格的字符串,比如书名或歌曲名。另外,scanf()遇到 %s 占位符,会在字符串变量末尾存储一个空字符 \0。

                                         **点击文字跳转 —> C语言基础!

        关于字符 \0,可观看上面我的相关文章,在(三、C语言基础—6.字符串和 \0)有所介绍。诚谢阅读!

        scanf()将字符串读入字符数组时,不会检测字符串是否超过了数组长度。所以,存储字符串时,很可能会超过数组的边界,导致预想不到的结果。为防止这种情况,使用 %s 占位符时,应该指定读入字符串的最长长度,即写成 %[m]s ,其中的[m]是一个整数,表示读取字符串的最大长度,后面的字符将被丢弃。

        我们看到,在限制了字符串的最大长度为4后,屏幕上只打印了 Hell ,而后面的部分字符串都被丢弃了。

        然后我们再来回答上面提出的问题。数组 arr 的最大长度设定为5,scanf()读取字符串的时候最大却只能读取4,那是因为字符串的末尾隐藏放着一个字符 \0,\0 字符是字符串的结束标志。同样的,我在上篇文章中也有粗略介绍。

        2.4赋值忽略符

        有时,用户的输入可能不符合预定的格式。比如:

        我们规定的输入格式为:year-month-day,当我们输入其他格式时,就不能正确输出,大致可以说为容错率太小。那为了提高容错率,方便用户输入,scanf()提供了一个赋值忽略符 *(赋值忽略符也是字符)。只要把 * 加在任何占位符的百分号后面,该占位符就不会返回值,解析后将被丢弃。

        可以看到,就算格式多样打印出来的数值也都是正确的。这就是赋值忽略符带来的方便之处。

        说到这里友友们有没有跟我一样,之前觉得printf()函数、scanf()函数功能挺单一挺好掌握的,认真学起来没想到它原来深藏不露并且有点复杂呢?不过只要我们多用多练,这些都是假牙(我们高数老师的口头禅)。加油!!

                                 点击跳转主页—> 💥个人主页:小羊在奋斗

  • 17
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 以下是一个使用 printfscanf 的示例程序: ``` #include <stdio.h> int main() { int age; printf("请输入您的年龄: "); scanf("%d", &age); printf("您的年龄是: %d\n", age); return 0; } ``` 在这个程序中, printf 函数用于向屏幕输出 "请输入您的年龄: ", 而 scanf 函数用于从键盘读入一个整数(%d)并存储在变量 age 中. 最后, printf 函数再次被调用, 使用输入的年龄来输出 "您的年龄是: %d\n" . ### 回答2: printfscanf是C语言中的两个函数,用于输入输出。 printf函数用于将数据输出到屏幕上。它的语法如下: ```C int printf(const char* format, ...); ``` 其中,format是一个字符串,用于格式化输出的控制。...代表可变参数的部分,可以输出多个值。 例如,如果要输出一个整数,可以使用以下语句: ```C int num = 10; printf("数字是:%d\n", num); ``` 这会在屏幕上输出:"数字是:10"。 scanf函数用于从用户输入中读取数据。它的语法如下: ```C int scanf(const char* format, ...); ``` scanf函数根据format字符串的格式要求,从标准输入中读取相应数据,并将其存储到变量中。 例如,如果要从用户输入读取一个整数,可以使用以下语句: ```C int num; scanf("%d", &num); ``` 这会等待用户在控制台输入一个整数,并将输入的值存储到num变量中。 下面是一个简单的示例,在屏幕上输出"请输入一个整数:",然后从用户输入中读取一个整数,并输出"你输入的整数是:X",其中X是用户输入的整数。 ```C #include <stdio.h> int main() { int num; printf("请输入一个整数:"); scanf("%d", &num); printf("你输入的整数是:%d\n", num); return 0; } ``` 以上就是printfscanf简单示例,它们在C语言中经常用于输入输出操作。 ### 回答3: printfscanf是C语言中的两个常用函数。 printf函数用于输出信息到终端或者文件。它的原型为:int printf(const char *format, ...),其中format是格式控制字符串,用于指定输出的格式,而...表示可以接受多个参数。printf函数可以输出各种类型的数据,如整数、浮点数、字符串等。在格式控制字符串中,我们可以使用一些特定的控制符来指定输出的数据类型,比如%d表示输出整数,%f表示输出浮点数,%s表示输出字符串等。通过使用printf函数,我们可以在程序运行过程中输出一些提示信息、计算结果等,以便用户了解程序的执行情况。 scanf函数用于从终端或者文件中输入数据。它的原型为:int scanf(const char *format, ...),其中format是格式控制字符串,用于指定输入的格式,而...表示可以接受多个参数。scanf函数可以接受各种类型的数据,如整数、浮点数、字符串等。在格式控制字符串中,我们可以使用一些特定的控制符来指定输入的数据类型,比如%d表示输入整数,%f表示输入浮点数,%s表示输入字符串等。通过使用scanf函数,我们可以在程序运行过程中从用户处获取输入的数据,以便程序进行相应的计算或处理。 以下是一个简单printfscanf的示例程序: ```c #include <stdio.h> int main() { int num1, num2; printf("请输入两个整数:\n"); scanf("%d %d", &num1, &num2); printf("您输入的两个数分别为:%d和%d\n", num1, num2); return 0; } ``` 在上述程序中,我们先使用printf函数输出提示信息,然后使用scanf函数从用户输入中获取两个整数,最后通过使用printf函数输出用户输入的两个整数。这样,我们就实现了一个简单printfscanf的演示程序。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值