time

time包

time 包提供了一些关于时间显示和测量用的函数。

time.Time类型表示时间。通过time.Now()获取当前时间对象,从而能拿到年月日时分秒等信息

Location和time zone

Go 语言中使用 location 来映射具体的时区。时区(Time Zone)是根据世界各国家与地区不同的经度而划分的时间定义,全球共分为24个时区。中国差不多跨5个时区,但为了使用方便只用东八时区的标准时即北京时间为准。

时间戳

获取时间戳

func timestampDemo() { now := time.Now() //获取当前时间 timestamp1 := now.Unix() //时间戳 timestamp2 := now.UnixNano() //纳秒时间戳 fmt.Printf("current timestamp1:%v\n", timestamp1) fmt.Printf("current timestamp2:%v\n", timestamp2) } 1234567

将时间戳转换为时间

func timestampDemo2(timestamp int64) { timeObj := time.Unix(timestamp, 0) //将时间戳转为时间格式 int参数时对毫秒进行加减操作 fmt.Println(timeObj) year := timeObj.Year() //年 month := timeObj.Month() //月 day := timeObj.Day() //日 hour := timeObj.Hour() //小时 minute := timeObj.Minute() //分钟 second := timeObj.Second() //秒 fmt.Printf("%d-%02d-%02d %02d:%02d:%02d\n", year, month, day, hour, minute, second) }

时间间隔

time.Duration是time包定义的一个类型,它代表两个时间点之间经过的时间,以纳秒为单位。time.Duration表示一段时间间隔,可表示的最长时间段大约290年。

Add

func (t Time) Add(d Duration) Time func main(){ now := time.Now() addNow := now.Add(time.Hour) // 当前时间加1小时 也可减1小时(-time.Hour) fmt.Println(addNow) }

Sub

求两个时间之间的差值:

func (t Time) Sub(u Time) Duration t1 := time.Now() time.Sleep(time.Second * 2) t2 := time.Now() timeSub := t2.Sub(t1) fmt.Println(timeSub)

Equal

func (t Time) Equal(u Time) bool

判断两个时间是否相同,会考虑时区的影响,因此不同时区标准的时间也可以正确比较。本方法和用t==u不同,这种方法还会比较地点和时区信息。

Before

func (t Time) Before(u Time) bool

如果t代表的时间点在u之前,返回真;否则返回假。

After

func (t Time) After(u Time) bool

如果t代表的时间点在u之后,返回真;否则返回假。

定时器

使用time.Tick(时间间隔)来设置定时器,定时器的本质上是一个通道(channel)。

func tickDemo() { ticker := time.Tick(time.Second) //定义一个1秒间隔的定时器 for i := range ticker { fmt.Println(i)//每秒都会执行的任务 } }

时间格式化

time.Format函数能够将一个时间对象格式化输出为指定布局的文本表示形式,需要注意的是 Go 语言中时间格式化的布局不是常见的Y-m-d H:M:S,而是使用 2006-01-02 15:04:05.000

  • 如果想格式化为12小时格式,需在格式化布局中添加PM。
  • 小数部分想保留指定位数就写0,如果想省略末尾可能的0就写 9。

解析字符串格式的时间

对于从文本的时间表示中解析出时间对象,time包中提供了time.Parse和time.ParseInLocation两个函数。

其中time.Parse在解析时不需要额外指定时区信息。

time.ParseInLocation函数需要在解析时额外指定时区信息。

flag

flag包实现了命令行参数的解析

flag包工作流程

  1. 注册flag,主要用flag.String(), Bool(), Int()等函数注册flag,或者用flag.BoolVar(),StringVar(),IntVar()等函数把flag绑定到变量.
  2. 解析flag,使用flag.Parse()函数解析在命令行使用了的flag。
  3. 最后根据命令行输入的flag处理逻辑

flag参数类型

flag包支持的命令行参数类型有bool、int、int64、uint、uint64、float float64、string、duration。

flag参数

有效值

字符串flag

合法字符串

整数flag

1234、0664、0x1234等类型,也可以是负数。

浮点数flag

合法浮点数

bool类型flag

1, 0, t, f, T, F, true, false, TRUE, FALSE, True, False。

时间段flag

任何合法的时间段字符串。如”300ms”、”-1.5h”、”2h45m”。

合法的单位有”ns”、”us” /“µs”、”ms”、”s”、”m”、”h”。

定义命令行flag参数

flag.Type()

基本格式如下:

flag.Type(flag名, 默认值, 帮助信息)*Type 例如我们要定义姓名、年龄、婚否三个命令行参数,我们可以按如下方式定义:

name := flag.String("name", "张三", "姓名") age := flag.Int("age", 18, "年龄") married := flag.Bool("married", false, "婚否") delay := flag.Duration("d", 0, "时间间隔")

需要注意的是,此时name、age、married、delay均为对应类型的指针。

flag.TypeVar()

基本格式如下: flag.TypeVar(Type指针, flag名, 默认值, 帮助信息)

主要结构体

注册flag就是初始化这个Flag

// A Flag represents the state of a flag. type Flag struct { Name string // name as it appears on command line Usage string // help message Value Value // value as set DefValue string // default value (as text); for usage message }

flag.Parse

定义好命令行flag参数后,需要调用flag.Parse()来对命令行参数进行解析

支持的命令行参数格式有以下几种:

  • -flag xxx (使用空格,一个-符号)
  • --flag xxx (使用空格,两个-符号)
  • -flag=xxx (使用等号,一个-符号)
  • --flag=xxx (使用等号,两个-符号)

其中,布尔类型的参数必须使用等号的方式指定。

Flag解析在第一个非flag参数(单个”-“不是flag参数)之前停止,或者在终止符”–“之后停止。

FlagSet

在命令行中使用的所有flag会被解析成一个FlagSet, 我们可以直接使用flag包的Bool(),BoolVar,Parse(),Nflag(),Usage,Visit()等函数去处理flag,这是因为flag包中已经定义了一个FlagSet,名为CommandLine。 我们也可以用NewFlagSet()自己定义一个新的FlagSet去处理命令行flag。

区别在于,CommandLine会在Parse()发生错误时退出,而NewFlagSet()可以自定义ErrorHandling

flag其他函数

flag.Args() 返回命令行参数后的其他参数,以[]string类型 flag.NArg() //返回命令行参数后的其他参数个数 flag.NFlag() //返回使用的命令行参数个数

方法介绍

Bool(),String(),Int(),BoolVar,StringVar(),IntVar(),Var()都是注册flag的方法

Parse()是从命令行解析flag的方法

Lookup(name string),判断是否使用了这个flag

NFlag(),返回命令行使用的flag数

Visit(),按照字母顺序遍历所有在命令行使用的flag

VisitAll(),按照字母顺序遍历所有注册过的flag

PrintDefaults(),打印所有已定义参数的默认值,默认输出到标准错误。(用 VisitAll 实现)