登录
首页 >  Golang >  Go问答

为何 *time.Time 在显示时是时间戳而不是内存地址?

来源:stackoverflow

时间:2024-03-23 20:09:38 433浏览 收藏

在 Go 中,time.Time 类型具有 String() 方法,可将时间戳转换为可读格式。当使用 fmt.Printf() 打印 *time.Time 指针时,它会调用 String() 方法并显示时间戳,而不是内存地址。这是因为 String() 方法包含在指针接收器方法集中,该方法集还包括值接收器方法。因此,*time.Time 也具有 String() 方法,该方法优先于默认的内存地址打印行为。

问题内容

我一直在从事一个业余爱好项目,并且已经达到了需要区分初始化零值和任何具有部分更新能力的请求的有意零值的地步。经过大量阅读后,我选择了制作所有传入结构字段指针的路线。由于指针初始化为 nil,并且 json 编组器绑定零值,因此我可以进行区分。我开始发送一些 api 请求,一开始就看到了我所期望的结果,结果如下:

{0xc00058e240 }

当我向结构中添加 time.time 字段并发送时间戳时,我看到了以下内容:

{0xc0004060d0  2004-10-16 00:00:00 +0000 utc}

我希望时间戳也是指向某个内存位置的指针。我用下面的方法进行了更多测试,它仍然打印时间戳。我的印象是,如果您尝试在操作中使用 *variable ,它会为您抛出错误。下面的代码按预期工作,所以它就像 time.time 是一个指针,即使它以正常格式直接从结构中打印。

type updateTestRequest struct {
    TestString    *string    `json:"test_string" binding:"alphanum"`
    TestName   *string    `json:"test_name,omitempty"`
    TestTime *time.Time `json:"test_time" time_format:"2006-01-02" binding:"required"`
}

func (server *Server) updateTest(ctx *gin.Context) {
    var req updateUserRequest
    if err := ctx.ShouldBindJSON(&req); err != nil {
        ctx.JSON(http.StatusBadRequest, errorResponse(err))
        return
    }
    fmt.Printf("%v", req)
    if req.TestTime != nil {
        fmt.Printf("value: '%v'", *req.TestTime)
    } else {
        println("it was nil.")
    }
    
}

{
    "test_string":"Testing",
    "first_name": "",
    "date_of_birth": "2004-10-16T00:00:00.00Z"
}

我对 golang 还很陌生,所以这可能是我对这门语言的误解。为什么时间戳不像其他指针那样打印为内存地址?


正确答案


time package documentation显示time.Time有一个String() string方法。由于指针接收器方法集包括值接收器方法,因此 *time.Time 还具有 String() string 方法。

fmt package documentation 说:

如果格式(对于 Println 等隐式为 %v)对于字符串 (%s %q %v %x %X) 有效,则应用以下两个规则:

  1. 如果操作数实现方法 String() string,则会调用该方法将对象转换为字符串,然后根据动词(如果有)的要求进行格式化。

因此,*time.Time 使用时间的 String() 方法的结果来显示。

今天关于《为何 *time.Time 在显示时是时间戳而不是内存地址?》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

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