Golang 中的 time 包详解(四):函数详解

在日常开发过程中,会频繁遇到对时间进行操作的场景,使用 Golang 中的 time 包可以很方便地实现对时间的相关操作。接下来的几篇文章会详细讲解 time 包,本文讲解一下 time 包中的函数。

func Now() Time

返回当前的系统时间。

package main

import (
	"fmt"
	"time"
)

func main() {
  now := time.Now()  
  fmt.Println(now.Unix())
}

func Parse(layout, value string) (Time, error)

将字符串解析为时间类型,并返回对应的 Time 对象。layout 参数是表示时间的格式,例如"2006-01-02 15:04:05"表示年、月、日、时、分、秒的格式。

package main

import (
	"fmt"
	"time"
)

func main() {
  layout := "2006-01-02 15:04:05"  
  str := "2023-07-19 12:34:56"  
  t, _ := time.Parse(layout, str)  
  fmt.Println(t)
}

func ParseDuration(s string) (Duration, error)

用于将字符串解析为 Duration 类型。

package main

import (
	"fmt"
	"time"
)

func main() {
	durationStr := "2h45m"
	duration, err := time.ParseDuration(durationStr)
	if err != nil {
		fmt.Println("解析持续时间错误:", err)
		return
	}
	fmt.Printf("解析后的持续时间为:%v\n", duration)
}

func ParseInLocation(layout, value string, loc *Location) (Time, error)

用于将字符串解析为 Time 类型,并在指定的时区中解析时间。

package main

import (
	"fmt"
	"time"
)

func main() {
	location := time.FixedZone("CustomZone", 2*60*60) // 创建一个偏移量为2小时的固定时区
	timeString := "2023-07-18 14:30:00"               // 要解析的字符串

	t, err := time.ParseInLocation("2006-01-02 15:04:05", timeString, location)
	if err != nil {
		fmt.Println("解析时间错误:", err)
		return
	}
	fmt.Printf("解析后的时间为:%v\n", t)
}

func Date(year int, month Month, day, hour, min, sec, nsec int, loc *Location) Time

根据给定的年、月、日、时、分、秒和纳秒创建一个 Time 对象,loc 参数表示时区。

package main

import (
	"fmt"
	"time"
)

func main() {
  t := time.Date(2023, 7, 19, 12, 34, 56, 0, time.UTC)  
  fmt.Println(t)
}

func Since(t Time) Duration

返回从当前时间到 t 之间的时间差,以纳秒为单位。

package main

import (
	"fmt"
	"time"
)

func main() {
  t := time.Date(2023, 7, 19, 12, 34, 56, 0, time.UTC)  
  duration := time.Since(t)  
  fmt.Println(duration)
}

func Until(t Time) Duration

返回从 t 到当前时间之间的时间差,以纳秒为单位。

package main

import (
	"fmt"
	"time"
)

func main() {
  t := time.Date(2023, 7, 19, 12, 34, 56, 0, time.UTC)  
  duration := time.Until(t)  
  fmt.Println(duration)
}

func After(d Duration) <-chan Time

用于创建一个通道,将在指定的时间间隔后向通道发送一个 time.Time 类型的值。

package main

import (
	"fmt"
	"time"
)

func main() {
	// 创建一个将在5秒后发送值的通道
	timer := time.After(5 * time.Second)

	// 等待通道发送值
	fmt.Println(<-timer)
}

func AfterFunc(d Duration, f func()) *Timer

用于创建一个定时器,并在指定的时间间隔后执行一个函数。

package main

import (
	"fmt"
	"time"
)

func main() {
	// 创建一个将在5秒后触发的定时器
	timer := time.AfterFunc(5*time.Second, func() {
		fmt.Println("路多辛的博客!")
	})

	// 停止定时器
	time.Sleep(10 * time.Second)
	timer.Stop()

	// 输出:路多辛的博客!
	fmt.Println("Program ended")
}

func Unix(sec int64, nsec int64) Time

用于将 Unix 时间戳转换为时间类型。

package main

import (
	"fmt"
	"time"
)

func main() {
	// 定义一个Unix时间戳
	unixTime := int64(1691587957)

	// 使用time.Unix函数将Unix时间戳转换为时间类型
	t := time.Unix(unixTime, 0)

	// 打印结果
	fmt.Println(t)
}

func UnixMilli(msec int64) Time

用于将毫秒时间戳转换为时间类型。

package main

import (
	"fmt"
	"time"
)

func main() {
	t := time.UnixMilli(1691587957000)

	// 打印结果
	fmt.Println(t)
}

func UnixMicro(usec int64) Time

用于将微秒时间戳转换为时间类型。

package main

import (
	"fmt"
	"time"
)

func main() {
	t := time.UnixMilli(1691587957000000)

	// 打印结果
	fmt.Println(t)
}

func Tick(d Duration) <-chan Time

用于创建一个定时器,该定时器每隔一定的时间间隔就会向通道发送当前的时间。

package main

import (
	"fmt"
	"time"
)

func main() {
	// 创建一个每隔1秒进行一次打印的定时器
	ticker := time.Tick(1 * time.Second)

	for {
		<-ticker // 等待定时器的发送
		fmt.Println("这是ticker的打印")
	}
}

func LoadLocation(name string) (*Location, error)

用于加载并返回一个特定的时区。

package main

import (
	"fmt"
	"time"
)

func main() {
	// 加载"Asia/Shanghai"时区
	location, err := time.LoadLocation("Asia/Shanghai")
	if err != nil {
		fmt.Println("无法加载时区:", err)
		return
	}

	// 使用该时区创建一个时间对象
	t := time.Now().In(location)
	fmt.Println("当前时间:", t)
}

func LoadLocationFromTZData(name string, data []byte) (*Location, error)

用于从 TZ 数据中加载并返回一个时区。

package main

import (
	"fmt"
	"time"
)

func main() {
	// 加载"Asia/Shanghai"时区
	location, err := time.LoadLocationFromTZData("Asia/Shanghai")
	if err != nil {
		fmt.Println("无法加载时区:", err)
		return
	}

	// 使用该时区创建一个时间对象
	t := time.Now().In(location)
	fmt.Println("当前时间:", t)
}

func FixedZone(name string, offset int) *Location

用于创建一个具有固定偏移量的时区。

package main

import (
	"fmt"
	"time"
)

func main() {
	// 创建一个偏移量为2小时的固定时区
	location := time.FixedZone("CustomZone", 2*60*60)

	// 使用该时区创建一个时间对象
	t := time.Now().In(location)
	fmt.Println("当前时间:", t)
}

func NewTicker(d Duration) *Ticker

用于创建一个新的 Ticker 对象,该对象可以在指定的时间间隔重复发送 Time 值。

package main

import (
	"fmt"
	"time"
)

func main() {
	// 创建一个每秒发送一次的 Ticker 对象
	ticker := time.NewTicker(1 * time.Second)
	defer ticker.Stop()

	for {
		select {
		case <-ticker.C:
			fmt.Println("打印一次路多辛的博客")
		}
	}
}

func NewTimer(d Duration) *Timer

用于创建一个新的 Timer 对象,该对象可以在指定的时间间隔后发送一个 Time 类型的值。

package main

import (
	"fmt"
	"time"
)

func main() {
	// 创建一个定时器,在2秒后发送一个时间值
	timer := time.NewTimer(2 * time.Second)
	defer timer.Stop()

	// 使用定时器发送的时间值处理函数
	timerHandler := func() {
		fmt.Println("收到时间值")
	}

	// 在定时器发送时间值之前执行处理函数
	go timerHandler()

	// 等待定时器发送时间值
	select {
	case <-timer.C:
		fmt.Println("定时器已发送时间值")
	}
}

func Sleep(d Duration)

让当前的 goroutine 休眠指定的时间。

package main

import (
	"fmt"
	"time"
)

func main() {
	fmt.Println("开始休眠")
	time.Sleep(2 * time.Second)
	fmt.Println("休眠结束")
}

你可能感兴趣的:(Golang系列知识讲解,golang,开发语言,后端)