登录
首页 >  Golang >  Go问答

为何将记录保存在GoLang中的标准输入?

来源:stackoverflow

时间:2024-03-02 09:33:27 321浏览 收藏

一分耕耘,一分收获!既然打开了这篇文章《为何将记录保存在GoLang中的标准输入?》,就坚持看下去吧!文中内容包含等等知识点...希望你能在阅读本文后,能真真实实学到知识或者帮你解决心中的疑惑,也欢迎大佬或者新人朋友们多留言评论,多给建议!谢谢!

问题内容

log.New(os.Stdin, "in", 1).Println("TT")

以下代码输出流看起来应该使用 stdout 或 stderr,但我使用的是 stdin 输入流。 它应该会陷入一些恐慌,但会正常输出到控制台。

为什么这个工作正常? 我不知道为什么。

um 流输入不是用来在键盘上打字的吗?但由于我将流输入输入到输出,我认为这不起作用。标准输出:控制台, 标准错误:控制台, 标准输入:键盘


正确答案


tl;dr - 来自源代码:

var (
    stdin  = newfile(uintptr(syscall.stdin), "/dev/stdin")
    stdout = newfile(uintptr(syscall.stdout), "/dev/stdout")
    stderr = newfile(uintptr(syscall.stderr), "/dev/stderr")
)

stdin、stdout 和 stderr 是指向标准的开放文件 输入、标准输出和标准错误文件描述符。

这实际上意味着 go 将 stdin、stdout 和 stderr 视为相同的,就像普通文件一样。为什么不应该呢?他们确实就是这样。如果您在选择的 shell 中运行 echo sometext > /dev/stdin,您将看到这是有效的,并且文本“sometext”将被打印到终端

深入挖掘

让我们检查一下 log.new 函数声明:

func new(out io.writer, prefix string, flag int) *logger

new 创建一个新的记录器。 out 变量将目的地设置为 将写入哪些日志数据。前缀出现在开头 每个生成的日志行,或者在日志标头之后(如果 lmsgprefix) 提供了标志。标志参数定义日志记录属性。

您可以看到第一个参数是 io.writer 接口 - 声明为:

type Writer interface {
    Write(p []byte) (n int, err error)
}

这实际上意味着 log.new 接受每个具有 write(p []byte) (n int, err error) 方法的结构。并且由于os.stdin的类型为os.File,因此它匹配io.writer接口规范和log.new的签名。

今天关于《为何将记录保存在GoLang中的标准输入?》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

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