Golang time包中的函数用法详解

 更新时间:2023年08月10日 09:42:06   作者:路多辛  
在日常开发过程中,会频繁遇到对时间进行操作的场景,使用 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 time包中的函数详解的详细内容,更多关于Golang time包函数的资料请关注脚本之家其它相关文章!

相关文章

  • GOLang单元测试用法详解

    GOLang单元测试用法详解

    Go语言中自带有一个轻量级的测试框架testing和自带的go test命令来实现单元测试和性能测试。本文将通过示例详细聊聊Go语言单元测试的原理与使用,需要的可以参考一下
    2022-12-12
  • golang中的nil接收器详解

    golang中的nil接收器详解

    这篇文章主要介绍了golang中的nil接收器,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-10-10
  • 使用go自定义prometheus的exporter

    使用go自定义prometheus的exporter

    在prometheus中如果要监控服务器和应用的各种指标,需要用各种各样的exporter服务,这篇文章主要介绍了使用go自定义prometheus的exporter,需要的朋友可以参考下
    2023-03-03
  • Go语言实现热更新具体步骤

    Go语言实现热更新具体步骤

    这篇文章主要为大家介绍了Go语言实现热更新具体步骤详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2024-01-01
  • Go实现map转json的示例详解

    Go实现map转json的示例详解

    这篇文章主要为大家详细介绍了如何利用Go语言实现map转json的功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-09-09
  • go Cobra命令行工具入门教程

    go Cobra命令行工具入门教程

    Cobra是一个用Go语言实现的命令行工具并且现在正在被很多项目使用,例如:Kubernetes、Hugo和Github CLI等,通过使用Cobra,我们可以快速的创建命令行工具,特别适合写测试脚本,各种服务的Admin CLI等,本文重点给大家介绍go Cobra命令行工具,感兴趣的朋友一起看看吧
    2022-06-06
  • Go Generate 代替 Makefile使用方法详解

    Go Generate 代替 Makefile使用方法详解

    这篇文章主要为大家介绍了Go Generate 代替 Makefile使用方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • Golang中fsnotify包监听文件变化的原理详解

    Golang中fsnotify包监听文件变化的原理详解

    Golang提供了一个强大的fsnotify包,它能够帮助我们轻松实现文件系统的监控,本文将深入探讨fsnotify包的原理,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-12-12
  • 在Go语言程序中使用gojson来解析JSON格式文件

    在Go语言程序中使用gojson来解析JSON格式文件

    这篇文章主要介绍了在Go语言程序中使用gojson来解析JSON格式文件的方法,Go是由Google开发的高人气新兴编程语言,需要的朋友可以参考下
    2015-10-10
  • 浅谈Go语言的error类型

    浅谈Go语言的error类型

    这篇文章主要介绍了浅谈Go语言的error类型,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12

最新评论