登录
首页 >  Golang >  Go问答

为什么 fmt.Scanf 中的 %d 之后的换行符被忽略,而 %c 却没有被忽略?

来源:stackoverflow

时间:2024-02-12 18:27:25 342浏览 收藏

在Golang实战开发的过程中,我们经常会遇到一些这样那样的问题,然后要卡好半天,等问题解决了才发现原来一些细节知识点还是没有掌握好。今天golang学习网就整理分享《为什么 fmt.Scanf 中的 %d 之后的换行符被忽略,而 %c 却没有被忽略?》,聊聊,希望可以帮助到正在努力赚钱的你。

问题内容

package main

import (
    "fmt"
    "log"
)

func main() {
    var num int
    n, err := fmt.Scanf("%d", &num)
    fmt.Println(n, num)
    if err != nil {
        log.Fatalln(err)
    }

    var r1 rune
    n, err = fmt.Scanf("%c", &r1)
    fmt.Println(n, r1)
    if err != nil {
        log.Fatalln(err)
    }

    var r2 rune
    n, err = fmt.Scanf("%c", &r2)
    fmt.Println(n, r2)
    if err != nil {
        log.Fatalln(err)
    }
}

输入(键盘按键)是: 1 输入 a 输入

输出是:

1 1

1 97

1 10

为什么 r2 的值为 \nr1 的值为 a

fmt.scanf的评论中:

输入中的换行符必须与格式中的换行符匹配。一个例外:动词 %c 始终扫描输入中的下一个符文,即使它是空格(或制表符等)或换行符。

看起来 %d 之后的换行符被吃掉了,但 %c 之后的换行符没有被吃掉。 %d 后面的换行符是否未匹配?

另一个例子:https://play.studygolang.com/p/lrgxruqybti,我尝试使用缓冲区来代替标准输入,但输出与使用标准输入不同。

go版本是go版本go1.17.1 windows/amd64


正确答案


换行符是单个字符,对于 rune 来说是有效输入,但对于 int 来说不是,因此当您捕获 rune 时,会读取并存储新行,而对于其他类型则不会这样做。

如果您在读取符文时没有捕获新行,那么当您尝试再次从标准输入读取时,您将收到错误“意外的 newlnie”。

我建议您执行以下操作来读取符文,以便始终捕获换行符并且不会得到意外结果

var r1, r2 rune
n, err = fmt.Scanf("%c%c", &r1, &r2)
fmt.Println(n, r1, r2)
if err != nil {
    log.Fatalln(err)
}

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>