GO标准包之fmt、log

本文深入探讨了Go语言中fmt包的功能,包括不同类型的输入输出操作,如打印、格式化和扫描。同时,详细介绍了log包的使用,包括创建日志记录器、设置日志前缀和标志,以及如何将日志输出到文件。文章还讨论了log包的局限性,为读者提供了更高级日志需求的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在fmt包中,主要是输入和输出

对于输出:print
有三大类:pringf fprintf sprintf
print fprint sprint
println fprintln sprintln
通过书写可以看出

第一行的按照格式化文本输出内容
第二行输出时不会换行
第三行的会换行

而第一列的是输出内容到os.stdout
第二列是io.writer
第三列是字符串

同样的对于scan
有三大类 scanf fscanf sscanf
scan fscan sscan
scanln fscanln sscanln
与上面一样,带ln结束的是读取到下一行停止;什么都不带的是无限制换行;带f的是格式化文本输入

以f开头的是从io.reader读取;以s开头的是从一个参数字符串读取文本;什么都不带得到是从os.stdin读取文本

LOG包
通过log的new函数可以得到一个logger的结构体指针

type Logger struct {
	mu     sync.Mutex // ensures atomic writes; protects the following fields
	prefix string     // prefix to write at beginning of each line
	flag   int        // properties
	out    io.Writer  // destination for output
	buf    []byte     // for accumulating text to write
}


func New(out io.Writer, prefix string, flag int) *Logger {
	return &Logger{out: out, prefix: prefix, flag: flag}
}

out中只要实现了io.writer都可以作为out,比如说os文件流
pfefix可以指定日志信息的前缀,比如说[debug]等等
flag设置的时间格式,一般使用默认得到LstdFlags就可以

logfile, err := os.OpenFile("my.log", os.O_RDWR|os.O_CREATE|os.O_APPEND, 0644)
if err != nil {
	log.Fatalln("fail to create log file!")
}
defer logfile.Close()

l:=log.New(logfile, "", log.LstdFlags)
l.Println("test")
num:=5
l.Println("test %d",num)

这样log包的日志功能基本上能满足一般的开发需要,但相对还是比较简单,缺少日志分层控制,缺少对json格式的支持等,所以如果有需要灵活定制或大并发、大吞吐量的日志开发需求,建议考虑使用其他方法或途径来实现。

<think>好的,用户想了解Go语言中fmt包的用法和功能。首先,我需要整理fmt包的主要功能,包括格式化输入输出,比如Print、Printf、Println的区别,以及Sprintf、Fprintf等函数的用途。然后,要详细说明常用的格式化动词,比如%v、%T、%d等,并给出具体的例子,这样用户更容易理解。另外,输入相关的函数如Scan、Scanf、Scanln也需要介绍,说明它们的使用场景。可能还需要提到错误处理和格式化选项,比如宽度、精度、对齐方式等。 根据用户提供的引用内容,引用1和引用2提到了fmt包的重要性以及Printf的格式化选项,引用3是关于Fprintf的函数签名。需要将这些信息整合到回答中,确保引用标记正确。同时,用户的问题还要求生成相关问题,所以得想几个相关的问题,比如如何控制输出宽度,输入函数的区别,或者如何自定义类型的格式化输出。 需要注意的是,回答的结构要清晰,分点说明,同时代码示例要用正确的格式,比如使用反引号包裹Go代码。另外,数学表达式要用$...$,但在这个问题中可能涉及较少,不过如果有示例中的数字或变量,需要注意格式。最后,确保语言口语化,避免使用专业术语过多,让用户容易理解。</think># Go语言fmt包使用说明与功能介绍 ## 一、基础功能概述 Go语言的fmt包是处理格式化输入输出的核心工具包,提供超过20个格式化动词和多种控制选项。主要功能模块包含: 1. **标准输出函数** - `Print()`:基础输出,不换行 - `Println()`:自动添加换行和空格分隔 - `Printf()`:支持格式化模板输出 ```go fmt.Printf("字符串:%s 整数:%d 浮点:%.2f\n", "hello", 42, 3.1415) ``` 2. **字符串构建函数** - `Sprintf()`:返回格式化字符串 ```go s := fmt.Sprintf("当前温度:%v°C", 23.5) ``` 3. **流式输出函数** - `Fprintf()`:向指定io.Writer写入 ```go file, _ := os.Create("log.txt") fmt.Fprintf(file, "错误代码:%05d", 404) ``` ## 二、核心格式化参数(部分) | 动词 | 说明 | 示例 | 输出结果 | |------|-----------------------|---------------------|-----------------| | `%v` | 通用格式 | `%v`, 42 | 42 | | `%T` | 类型输出 | `%T`, "text" | string | | `%d` | 十进制整数 | `%05d`, 123 | 00123 | | `%f` | 浮点数 | `%.2f`, 3.1415 | 3.14 | | `%p` | 指针地址 | `%p`, &var | 0xc000018088 | ## 三、输入处理函数 1. **`Scan()`系列** ```go var name string fmt.Scan(&name) // 读取空格分隔输入 ``` 2. **`Scanf()`格式化输入** ```go fmt.Scanf("%d-%d", &year, &month) // 输入"2023-08" ``` 3. **`Scanln()`行读取** ```go fmt.Scanln(&address) // 读取整行输入 ``` ## 四、高级格式化控制 1. **宽度与精度** ```go fmt.Printf("|%8.2f|%-8s|", 3.1416, "END") // 输出:| 3.14|END | ``` 2. **自定义类型格式化** 实现`Stringer`接口: ```go type Point struct{ X, Y int } func (p Point) String() string { return fmt.Sprintf("(%d,%d)", p.X, p.Y) } ``` ## 五、错误处理实践 格式化函数返回写入字节数和错误对象: ```go n, err := fmt.Fprintf(os.Stderr, "错误:%v", io.EOF) if err != nil { // 错误处理 } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值