微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

go time.Now没有给予适当的时间

如何解决go time.Now没有给予适当的时间

我正在运行这个简单的go程序,并希望获得3秒的睡眠时间,因此启动和关闭日志的时间将有所不同(相差3秒),但是我得到的时间却是相同的。

package main

import (
    "fmt"
    "time"
)

const (
    logInfo = "INFO"
    logWarning = "WARNING"
    logError = "ERROR"
)

type logEntry struct {
    time time.Time
    severity string
    message string
}

var myLogChannel = make(chan logEntry,50)

func main() {
    go logger()
    myLogChannel <- logEntry{ time.Now(),logInfo,"App is starting" }
    time.Sleep(3 * time.Second)
    fmt.Println("Time is :",time.Now().Format("2006-01-02 15:04:06"))
    myLogChannel <- logEntry{ time.Now(),"App is shuting down" }
    time.Sleep(2 * time.Second)
}
func logger() {
    for entry := range myLogChannel {
        fmt.Printf("%v : [%v]: %v\n",entry.time.Format("2006-01-02 15:04:06"),entry.severity,entry.message)
    }
}

输出: 在我的系统上(在cygwin env下运行): 2020-10-12 11:03:20:[INFO]:应用正在启动 时间是:2020-10-12 11:03:20 2020-10-12 11:03:20:[INFO]:应用程序正在关闭

在操场上: 2009-11-10 23:00:09:[INFO]:应用正在启动 时间是:2009-11-10 23:00:09 2009-11-10 23:00:09:[INFO]:应用程序正在关闭

解决方法

您的时间格式不正确。 06是一年的最后两位数字,因此它将打印2020年的20。使用格式:2006-01-02 15:04:05

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。