golang使用的版本:html
go version go1.10.3
time的一些功能,好比时区,像linux中的定时器,时间计算等linux
Time通常分为时间Time 和 时段Duration
time结构体定义:golang
type Time struct { wall unit64 //表示距离公元1年1月1日00:00:00UTC的秒数 ext int64 //表示纳秒 loc *Location //表明时区,主要处理偏移量。由于不一样的时区,对应的时间不同 }
上面的loc表示时区, 那什么是时区呢?
由于地球是圆的,因此同一个时刻,在地球的一边是白天,一边是黑夜。而由于人类使用一天 24 小时的制度,因此,在地球对角的两边就应该差了 12 的小时才对。因为同一个时间点上面, 整个地球的时间应该都不同,为了解决这个问题,因此能够想见的,地球就被分红 24 个时区了,
由于绕地球一圈是 360 度角,这 360 度角共分为 24 个时区,固然一个时区就是 15 度角啦! 又因为是以格林威治时间为标准时间( Greenwich Mean Time, GMT 时间),加上地球自转的关系,所以,在格林威治以东的区域时间是比较快的(+小时), 而以西的地方固然就是较慢啰!
UTC又是什么 ?
在计算时间的时候,最准确的计算应该是使用‘原子震荡周期’所计算的物理时钟了 (Atomic Clock, 也被称为原子钟),这也被定义为标准时间 (International Atomic Time)。而咱们经常看见的 UTC 也就是 Coordinated Universal Time (协和标准时间)就是利用这种 Atomic Clock 为基准所定义出来的正确时间。例如 1999 年在美国启用的原子钟 NIST F-1, 他所产生的时间偏差每两千年才差一秒钟!真的是很准呐! 这个 UTC 标准时间是以 GMT 这个时区为主的喔!因此本地时间与 UTC 时间的时差就是本地时间与 GMT 时间的时差就是了!
UTC + 时区差 = 本地时间,
国内通常使用的是北京时间,与UTC的时间关系以下:
UTC + 8个小时 = 北京时间
更多关于时间的内容请查看 鸟哥的私房菜
下面的这些函数都是返回结构体Time,至关于把不一样类型的日期格式初始化为结构体Time服务器
func Now() Time
例子1:函数
fmt.Println(time.Now()) //output: 2019-04-25 23:15:12.2473056 +0800 CST m=+0.042979701 fmt.Println(time.Now().Year(), time.Now().Month()) //output: 2019 April
从上面能够看出,Now()返回的是一个+0800 CST 的时间.net
func Parse(layout, value string, defaultLocation, local *Location) (Time, error)
layout 定义输入的时间格式,value 的时间格式需与 layout 保持一致线程
例子1:code
fmt.Println(time.Parse("2006-01-02 15:04:05", "2018-04-23 00:00:23")) //output: 2018-04-23 00:00:23 +0000 UTC <nil>
从上面示例能够看出,Parse()默认返回的是+0000 UTC 时间orm
ParseInLocation 功能与 Parse 相似,但有两个重要的不一样之处:server
func ParseInLocation(layout, value string, loc *Location) (Time, error)
例子1:
fmt.Println(time.ParseInLocation("2006-01-02 15:04:05", "2017-05-11 14:06:06", time.Local)) //output: 2017-05-11 14:06:06 +0800 CST <nil>
根据秒和纳秒返回一个时间
func Unix(sec int64, nsec int64) Time
例子1:
fmt.Println(time.Unix(1e9, 0)) //output:2001-09-09 09:46:40 +0800 CST
func Date(year int, month Month, day, hour, min, sec, nsec int, loc *Location) Time
例子1:
fmt.Println(time.Date(2018, 1, 2, 15, 30, 10, 0, time.Local)) //output: 2018-01-02 15:30:10 +0800 CST
返回本地时间
func (t Time) Local() Time
例子1:
fmt.Println(time.Now()) fmt.Println(time.Now().Local()) //output: 2019-03-26 00:51:19.5597562 +0800 CST m=+0.006832001 //output: 2019-03-26 00:51:19.5987973 +0800 CST
其余的返回Time的方法,请到 godoc 查看time方法列表
把时间(string)转化为string格式
func (t Time) Format(layout string) string
例子1:
fmt.Println(time.Now().Format("2006-01-02 15:04:05")) fmt.Println(time.Now().Format("2006/01/02")) //2019-03-26 01:20:55 //2019/03/26 const TimeFormat = "15:04:05" fmt.Println(time.Now().Format(TimeFormat)) //02:05:52 const MicroFormat = "2006/01/02 15:04:05.000000" fmt.Println(time.Now().Format(MicroFormat)) //2019/03/26 02:07:45.051045
func (t Time) Unix() int64
例子1:返回如今时间的时间戳
fmt.Println(time.Now().Unix()) // 1553580240
例子2:返回指定格式日期的时间戳
t, _ := time.Parse("2006-01-02 15:04:05", "2018-03-23 00:00:23") fmt.Println(t.Unix()) //1524441623
Unix(sec int64, nsec int64) Time
把时间time转化为日期date
例子1:
fmt.Println(time.Unix(time.Now().Unix(), 0)) //2019-03-26 02:03:45 +0800 CST
返回Time结构体后,就能够调用Time的一些方法获得年月日
例子1:
t := time.Now() fmt.Println(t.Year()) fmt.Println(t.Month()) fmt.Println(t.Day()) fmt.Pritnln(t.Weekday())
用Date() 函数实现
例子1:
t := time.Date(2012, 2, 20, 23, 59, 59, 0, time.UTC) fmt.Println(t) //2012-02-20 23:59:59 +0000 UTC t = time.Date(2012, 2, 20, 23, 59, 59, 0, time.Local) fmt.Println(t) //2012-02-20 23:59:59 +0800 CST
Date()函数后面还能够加一个时区参数,获得相关时区的日期
LoadLocation(name string) (*Location, error)
例子1:
loc, _ := time.LoadLocation("Asia/Shanghai") //设置时区 t, _ := time.ParseInLocation("2006-01-02 15:04:05", "2012-02-20 15:07:51", loc) fmt.Println(t) fmt.Println(t.Unix()) //获取时间戳 //2012-02-20 15:07:51 +0800 CST //1329721671
例子2:
loc, _ := time.LoadLocation("Asia/Shanghai") //设置时区 t := time.Unix(1329721671, 0) fmt.Println(t.In(loc).Format("2006-01-02 15:04:05")) //2012-02-20 15:07:51
loc, err := time.LoadLocation("") //默认UTC时间 loc, err := time.LoadLocation("local") //服务器设定本地时区,通常为CST loc, err := time.LoadLocation("Asia/Shanghai") //设置指定时区,指定为亚洲上海时区
type Duration int64
定义了如下持续时间类型.多用于时间的加减须要传入Duration作为参数的时候
const ( Nanosecond Duration = 1 Microsecond = 1000 * Nanosecond Millisecond = 1000 * Microsecond Second = 1000 * Millisecond Minute = 60 * Second Hour = 60 * Minute )
例子1:
这个咱们写一个完整的例子
package main import ( "fmt" "reflect" "time" ) func main() { fmt.Println(reflect.TypeOf(1)) fmt.Println(reflect.TypeOf(1 * time.Second)) } //int //time.Duration
func ParseDuration(s string) (Duration, error)
例子2:
td, _ := time.ParseDuration("2h20m") fmt.Println(td) fmt.Println("min:", td.Minutes(), "second:", td.Seconds()) //min: 140 second: 8400
func (t Time) Add(d Duration) Time
例子1:
t := time.Date(2012, 2, 20, 23, 59, 59, 0, time.Local) fmt.Println(t) t = t.Add(60 * time.Second) //加60秒 fmt.Println(t) t = t.Add(1 * time.Hour) //加1小时 fmt.Println(t) //output: //2012-02-20 23:59:59 +0800 CST //2012-02-21 00:00:59 +0800 CST //2012-02-21 00:59:59 +0800 CST
func (t Time) AddDate(years int, months int, days int) Time
例子2:
t = time.Date(2019, 3, 25, 23, 59, 59, 0, time.Local) t2 := t.AddDate(0, 0, 1) //增长 1日 fmt.Println(t2) t2 = t.AddDate(2, 0, 0) //增长 2年 fmt.Println(t2) //output: //2019-03-26 23:59:59 +0800 CST //2021-03-25 23:59:59 +0800 CST
func (t Time) Sub(u Time) Duration
func Since(t Time) Duration:
例子1:
t := time.Date(2019, 4, 25, 23, 59, 59, 0, time.Local) fmt.Println(t) sub := t.Sub(time.Now()) // t - time.Now() fmt.Println(sub) sub = time.Since(t) //time.Now() - t, 至关于time.Now().Sub(t) fmt.Println(sub)
func Until(t Time) Duration
函数原型
// Until returns the duration until t. // It is shorthand for t.Sub(time.Now()). func Until(t Time) Duration { return t.Sub(Now()) }
例子1:
t := time.Date(2019, 3, 25, 23, 59, 59, 0, time.Local) fmt.Println(t) t3 := time.Until(t) fmt.Println(t3) //至关于 t - Now() 至关于 t.Sub(time.Now())
func (t Time) Before(u Time) bool
func (t Time) After(u Time) bool
func (t Time) Equal(u Time) bool
例子1:
t := time.Date(2012, 2, 20, 23, 59, 59, 0, time.Local) now := time.Now() ok := t.Before(now) fmt.Println(ok) ok = t.After(now) fmt.Println(ok) ok = t.Equal(now) fmt.Println(ok) //true //false //false
Ticker: 按照指定的周期来调用函数或计算表达式
type Ticker struct { C <-chan Time // The channel on which the ticks are delivered. r runtimeTimer }
func NewTicker(d Duration) *Ticker
例子1:
能够取消定时
package main import ( "fmt" "time" ) func main() { //NewTicker 函数能够取消定时 ticker := time.NewTicker(time.Millisecond * 500) go func() { for t := range ticker.C { fmt.Println("Tick at", t) } }() time.Sleep(time.Millisecond * 1500) //阻塞 ticker.Stop() //中止ticker fmt.Println("Ticker stopped") } //Tick at 2019-03-26 18:53:34.3215978 +0800 CST m=+0.506824001 //Tick at 2019-03-26 18:53:34.8226754 +0800 CST m=+1.007901601 //Ticker stopped
例子2:不能取消定时的Tick,因此咱们通常用上面的NewTicker
package main import ( "fmt" "time" ) func main() { tick := time.Tick(2 * time.Second) for v := range tick { fmt.Println("Tick val:", v) } } //Tick val: 2019-03-26 18:04:10.3579389 +0800 CST m=+2.007946901 //Tick val: 2019-03-26 18:04:12.3586132 +0800 CST m=+4.008621301 //Tick val: 2019-03-26 18:04:14.3570512 +0800 CST m=+6.007059201 //Tick val: 2019-03-26 18:04:16.3580495 +0800 CST m=+8.008057601
Timer: Timer类型用来表明一个独立的事件,当设置的时间过时后,发送当前时间到channel
使用Timer定时器,超时后须要重置,才能继续触发
type Timer struct { C <-chan Time r runtimeTimer }
func NewTimer(d Duration) *Timer
func (t *Timer) Stop() bool
func (t *Timer) Reset(d Duration) bool
例子1:
package main import ( "fmt" "time" ) func main() { timer1 := time.NewTimer(2 * time.Second) <-timer1.C fmt.Println("Timer 1 expired") timer2 := time.NewTimer(time.Second) go func() { <-timer2.C fmt.Println("Timer 2 expired") }() stop2 := timer2.Stop() if stop2 { fmt.Println("Timer 2 stopped") } }
func AfterFunc(d Duration, f func()) *Timer
例子1:
package main import ( "fmt" "time" ) func main() { t := time.Second * 5 timer := time.AfterFunc(t, func() { fmt.Printf("you %d second timer finished", t) }) defer timer.Stop() time.Sleep(time.Second * 6) }
func After(d Duration) <-chan Time
例子1:
package main import ( "fmt" "time" ) func main() { done := make(chan struct{}) //采用协程等待结束 go func(ch <-chan time.Time) { fmt.Printf("Now is %s\n", <-ch) done <- struct{}{} // 通知主线程协程退出 }(time.After(time.Second * 3)) //调用After,将返回的只读信道传递给协程函数 <-done close(done) }