Time

Time #

// Go oferece suporte extenso para tempos e durações;
// Aqui estão alguns exemplos.

package main

import (
	"fmt"
	"time"
)

func main() {
	p := fmt.Println

	// Aqui é capturado o horário atual.
	now := time.Now()
	p(now)

	// Pode ser construída uma struct `time` provendo
	// ano, mês, dia, etc. Tempos (ou horários) sempre
	// estão associados com uma localização,
	// por exemplo, fuso-horário.
	then := time.Date(
		2009, 11, 17, 20, 34, 58, 651387237, time.UTC)
	p(then)

	// É possível extrair vários componentes do
	// valor horário.
	p(then.Year())
	p(then.Month())
	p(then.Day())
	p(then.Hour())
	p(then.Minute())
	p(then.Second())
	p(then.Nanosecond())
	p(then.Location())

	// Dia da semana, de Domingo a segunda, também está disponível
	// pela função `Weekday`.
	p(then.Weekday())

	// Estes métodos comparam dois tempos, testando se o primeiro
	// ocorre antes, depois ou ao mesmo segundo, respectivamente.
	p(then.Before(now))
	p(then.After(now))
	p(then.Equal(now))

	// O método `Sub` retorna a duração, `Duration`, representando
	// o intervalo entre dois tempos.
	diff := now.Sub(then)
	p(diff)

	// É possível computar o tamanho da duração em várias unidades.
	p(diff.Hours())
	p(diff.Minutes())
	p(diff.Seconds())
	p(diff.Nanoseconds())

	// Também se pode usar o `Add` para avançar o tempo por uma
	// duração determinada, ou com `-` para retroceder.
	p(then.Add(diff))
	p(then.Add(-diff))
}
$ go run time.go
2012-10-31 15:50:13.793654 +0000 UTC
2009-11-17 20:34:58.651387237 +0000 UTC
2009
November
17
20
34
58
651387237
UTC
Tuesday
true
false
false
25891h15m15.142266763s
25891.25420618521
1.5534752523711128e+06
9.320851514226677e+07
93208515142266763
2012-10-31 15:50:13.793654 +0000 UTC
2006-12-05 01:19:43.509120474 +0000 UTC

# Em seguida, será apresentado o conceito de
# tempo relativo à era Unix.