Golang log库 源码阅读

栏目: Go · 发布时间: 7年前

内容简介:Golang的log库。。。还是太简单,简单瞄了一下实现,差不多就是这样:测试用例:运行结果:

Golang的log库。。。还是太简单,简单瞄了一下实现,差不多就是这样:

package main

import (
    "fmt"
    "io"
    "os"
    "sync"
)

type Logger struct {
    mu  sync.Mutex
    out io.Writer
}

func New(out io.Writer) *Logger {
    return &Logger{out: out}
}

func (l *Logger) output(format string, v ...interface{}) {
    l.mu.Lock()
    defer l.mu.Unlock()

    l.out.Write([]byte(fmt.Sprintf(format, v...)))
}

func (l *Logger) Printf(format string, v ...interface{}) {
    l.output(format, v...)
}

func (l *Logger) Panicf(format string, v ...interface{}) {
    l.output(format, v...)
    panic("traceback:\n")
}

func (l *Logger) Fatalf(format string, v ...interface{}) {
    l.output(format, v...)
    os.Exit(1)
}

var std = New(os.Stderr)

func Printf(format string, v ...interface{}) {
    std.Printf(format, v...)
}

func Panicf(format string, v ...interface{}) {
    std.Panicf(format, v...)
}

func Fatalf(format string, v ...interface{}) {
    std.Fatalf(format, v...)
}

测试用例:

package main

func main() {
    std.Printf("this is: %d\n", 1)

    std.Panicf("bye\n")
}

运行结果:

root@arch test: ./main          
this is: 1                      
bye                             
panic: traceback:               


goroutine 1 [running]:          
main.(*Logger).Panicf(0xc42006a060, 0x4a7115, 0x4, 0x0, 0x0, 0x0)                                                                
        /root/test/mylog.go:32 +0xa8                            
main.main()                     
        /root/test/main.go:6 +0xeb                              
root@arch test:

以上所述就是小编给大家介绍的《Golang log库 源码阅读》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

创新者的处方

创新者的处方

[美]克莱顿·克里斯坦森、杰罗姆·格罗斯曼、黄捷升 / 朱恒鹏、张琦 / 中国人民大学出版社 / 2015-9 / 89.90元

[内容简介] ● 创新大师克里斯坦森采用了哈佛商学院在20年研究中总结而出的、在各行业实践中获得成功的管理创新经验,把颠覆式创新理念引入美国医疗行业研究。医疗机构需要量体裁衣,选择合适的商业模式展开创新之举。 ● 作者同时探讨了医疗保险公司、制药企业、医学院和政府机构在医疗改革中起到的作用,从社会性角度深入剖析了医疗保健行业未来之路。 ● 医疗界人士、政策制定者、对医疗界现......一起来看看 《创新者的处方》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换