小伙伴们有没有觉得学习Golang很有意思?有意思就对了!今天就给大家带来《在 golang 中,实现自定义类型的方法,因此不需要在 Println 中进行强制转换》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!
问题内容我对 golang 很陌生。下面的代码修改自: https://jordanorelli.com/post/32665860244/how-to-use-interfaces-in-go
为什么最后一行的 println 调用中需要 time.time()
?
为什么打印 val["created_at"]
不会产生相同的字符串结果?它会生成一个指针。
您会看到我做了一些尝试来创建与自定义时间戳类型一起使用的 println 函数。是否可以在 timestamp 自定义类型上定义一个函数,以便代码末尾的 println 函数输出字符串而不是指针?
我认为这也可能回答了我的问题: https://stackoverflow.com/a/6485229/4005067
但是有没有办法定义 timestamp 类型的某些函数,以便不需要强制转换?
package main
import (
"encoding/json"
"fmt"
"reflect"
"time"
)
// start with a string representation of our json data
var input = `
{
"created_at": "thu may 31 00:00:01 +0000 2012"
}
`
type timestamp time.time
func (t *timestamp) unmarshaljson(b []byte) error {
v, err := time.parse(time.rubydate, string(b[1:len(b)-1]))
if err != nil {
return err
}
*t = timestamp(v)
return nil
}
//func (t *timestamp) println(a ...interface{}) (n int, err error) {
// return fmt.println(time.time(*t))
//}
//func (t timestamp) string() string {
// return string(t)
//}
func main() {
// our target will be of type map[string]interface{}, which is a pretty generic type
// that will give us a hashtable whose keys are strings, and whose values are of
// type interface{}
var val map[string]timestamp
if err := json.unmarshal([]byte(input), &val); err != nil {
panic(err)
}
fmt.println(val)
for k, v := range val {
fmt.println(k, reflect.typeof(v))
}
fmt.println(val["created_at"])
fmt.println(reflect.typeof(val["created_at"]))
fmt.println(timestamp(val["created_at"]))
fmt.println(time.time(val["created_at"]))
}
动态演示的输出是:
map[created_at:{0 63474019201 0x5b0580}]
created_at main.Timestamp
{0 63474019201 0x5b0580}
main.Timestamp
{0 63474019201 0x5b0580}
2012-05-31 00:00:01 +0000 UTC
解决方案
定义 string
方法是一种方法,就像您上面尝试的那样。
通过一些小的修改我们就可以让它工作。
func (t Timestamp) String() string {
return time.Time(t).String()
}
终于介绍完啦!小伙伴们,这篇关于《在 golang 中,实现自定义类型的方法,因此不需要在 Println 中进行强制转换》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~编程网公众号也会发布Golang相关知识,快来关注吧!