go time.Now() 没有给出适当的时间

Ala*_*ing -3 time go

我正在运行这个简单的 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(), logInfo, "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)
    }
}
Run Code Online (Sandbox Code Playgroud)

输出:在我的系统上(在 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]:应用程序正在关闭

Bur*_*dar 5

你的时间格式不对。06 是年份的最后两位数字,所以打印的20是 2020 年。使用格式:2006-01-02 15:04:05