百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

golang中级进阶(一):time包、日期函数、指针详解

yuyutoo 2024-10-11 21:40 5 浏览 0 评论

目录

一、time包

1. time包的基本使用

2. format 格式化时间

3. unix 时间戳相互转换

二、日期函数

1. 字符串转时间戳

2. 时间间隔常量

3. 实践操作函数:Add、Sub、Equal、Befor、After

4. 定时器:Ticker、Sleep

三、指针

1. 定义指针

2. 指针取值

3. 指针传值

4. new make函数

一、time包

1. time包的基本使用

package main
 
import (
    "fmt"
    "time"
)
 
func main() {
    // 1.time包引用及基本使用
	now := time.Now()
	fmt.Println(now) // 2022-04-08 15:07:36.11502 +0800 CST m=+0.000130549
	// 获取可阅读的
	Y := now.Year()
	m := now.Month()
	d := now.Day()
	H := now.Hour()
	i := now.Minute()
	s := now.Second()
	fmt.Printf("%d-%d-%d %d:%d:%d\n", Y, m, d, H, i, s)           // 2022-4-8 15:12:51
	fmt.Printf("%d-%.2d-%.2d %.2d:%.2d:%.2d\n", Y, m, d, H, i, s) // 2022-04-08 15:13:22
	fmt.Printf("%d-%02d-%02d %02d:%02d:%02d\n", Y, m, d, H, i, s) // 2022-04-08 15:13:22
}

2. format 格式化时间

由于golang诞生于2006年01月02日 15点04分05秒,所以格式化的方式为:

12小时制:2006-01-02 03:04:05

24小时制:2006-01-02 15:04:05

    // 2. format 格式化时间
	/*
		由于go诞生于2006年01月02号 15点04分05秒。所以格式化的方式:
		12小时制:2006-01-02 03:04:05
		24小时制:2006-01-02 15:04:05
	*/
	fmt.Println(now.Format("2006-01-02 15:04:05")) //2022-04-08 15:22:37
	fmt.Println(now.Format("2006-01-02 03:04:05")) //2022-04-08 03:22:37

3. unix 时间戳相互转换

time.Unix(第一个参数接受的int64格式的,0)

// 3. 获取当前unix时间戳
	timestamp1 := now.Unix()     // 毫秒级别
	timestamp2 := now.UnixNano() // 纳秒级别(较少使用)
	fmt.Println(timestamp1)      // 1649402681
	fmt.Println(timestamp2)      // 1649402681151226000
 
	// 4.1格式化时间戳
	timestamp := 1649402681
	timeObj := time.Unix(int64(timestamp), 0)
	fmt.Println(timeObj) // 2022-04-08 15:24:41 +0800 CST
 
	year := timeObj.Year()
	month := timeObj.Month()
	day := timeObj.Day()
	hour := timeObj.Hour()
	minute := timeObj.Minute()
	second := timeObj.Second()
	fmt.Printf("%d-%d-%d %d:%d:%d\n", year, month, day, hour, minute, second)           // 2022-4-8 15:24:41
	fmt.Printf("%d-%.2d-%.2d %.2d:%.2d:%.2d\n", year, month, day, hour, minute, second) // 2022-04-08 15:24:41
	fmt.Printf("%d-%02d-%02d %02d:%02d:%02d\n", year, month, day, hour, minute, second) // 2022-04-08 15:24:41
 
	// 4.2 利用format格式化
	fmt.Println(timeObj.Format("2006-01-02 03:04:05")) // 2022-04-08 03:24:41
	fmt.Println(timeObj.Format("2006-01-02 15:04:05")) // 2022-04-08 15:24:41

二、日期函数

1. 字符串转时间戳

// 5. 字符串转换成时间戳
	t1 := "2022-01-04 17:12:11"
	tmp := "2006-01-02 15:04:05"
	end, _ := time.ParseInLocation(tmp, t1, time.Local) // 参数为:格式,要转换的时间,暂时未知。返回两个值 time error
	fmt.Println(end.Unix())                             // 1641287531

2. 时间间隔常量

// 6. 时间间隔常量
	fmt.Println(time.Nanosecond)  // 1ns
	fmt.Println(time.Microsecond) // 1μs
	fmt.Println(time.Millisecond) // 1ms
	fmt.Println(time.Second)      // 1s
	fmt.Println(time.Minute)      // 1m0s
	fmt.Println(time.Hour)        // 1h0m0s

3. 实践操作函数:Add、Sub、Equal、Befor、After

// 7. 时间操作函数:Add增加时间,Sub时间差值,Equal判断时间相等,Befor判断是否在之后,After判断是否在之前
	t2 := time.Now()
	fmt.Println(t2) // 2022-04-08 16:58:58.56189 +0800 CST m=+0.000248774
	later := t2.Add(time.Hour)
	fmt.Println(later) // 2022-04-08 17:58:58.56189 +0800 CST m=+3600.000248774
 
	sub := now.Sub(later)
	fmt.Println(sub) // -1h0m0.000224485s
 
	equal := now.Equal(later)
	fmt.Println(equal) // false
 
	befor := now.Before(later)
	fmt.Println(befor) // true
 
	after := now.After(later)
	fmt.Println(after) // false

4. 定时器:Ticker、Sleep

// 8.定时器 1.ticker 2.sleep
	ticker := time.NewTicker(time.Second) // 时间间隔为1秒
	n := 5
	// ticker.C 只返回一个值
	for v := range ticker.C {
		fmt.Println(v) // 每隔一秒执行一次
		n--
		if n == 0 {
			ticker.Stop() // 终止执行,如果没有stop 会占用内存
			break
		}
	}
	for {
		time.Sleep(time.Second)
		fmt.Println("我在执行......")
	}

三、指针

1. 定义指针

指针也是一个变量,但它是一种特殊的变量,它存储的数据不是一个普通的值,而是另 一个变量的内存地址。

通过前面的教程我们知道变量是用来存储数据的,变量的本质是给存储数据的内存地址 起了一个好记的别名。比如我们定义了一个变量 a := 10 ,这个时候可以直接通过 a 这个变量 来读取内存中保存的 10 这个值。在计算机底层 a 这个变量其实对应了一个内存地址。

package main
 
import "fmt"
 
func main() {
    // 定义指针
	var a = 10
	fmt.Printf("a的值为:%v a的类型:%T a的内存地址:%p\n", a, a, &a) // a的值为:10 a的类型:int a的内存地址:0xc00001c070
	p := &a
	fmt.Printf("p的值:%v p的类型:%T p的内存地址:%p\n", p, p, &p) // p的值:0xc00001c070 p的类型:*int p的内存地址:0xc00000e030
	*p = 21
	fmt.Printf("a的值为:%v a的类型:%T a的内存地址:%p\n", a, a, &a) // a的值为:21 a的类型:int a的内存地址:0xc00001c070
 
}

2. 指针取值

要搞明白 Go 语言中的指针需要先知道 3 个概念:指针地址、指针类型和指针取值 Go 语言中的指针操作非常简单,我们只需要记住两个符号:&(取地址)和 *(根据地址 取值)

// 指针取值 *xxx
	var b = 10
	c := &b
	d := *c
	fmt.Printf("b值%v b类型%T b内存地址%p\n", b, b, &b) // b值10 b类型int b内存地址0xc0000b2020
	fmt.Printf("c值%v c类型%T c内存地址%p\n", c, c, &c) // c值0xc0000b2020 c类型*int c内存地址0xc0000ac028
	fmt.Printf("d值%v d类型%T d内存地址%p\n", d, d, &d) // d值10 d类型int d内存地址0xc00001c090

3. 指针传值

每个变量在运行时都拥有一个地址,这个地址代表变量在内存中的位置。Go 语言中使用& 字符放在变量前面对变量进行取地址操作。 Go 语言中的值类型(int、float、bool、string、 array、struct)都有对应的指针类型,如:*int、*int64、*string 等。

package main
 
import "fmt"
 
func fn1(x int) {
	x = 10
}
 
func fn2(x *int) {
	*x = 20
}
 
func main() {
    // 指针传值 引用数据类型 随之改变
	var e = 5
	fn1(e)
	fmt.Println(e) // 5
	fn2(&e)
	fmt.Println(e) // 20
}

取地址操作符&和取值操作符*是一对互补操作符,&取出地址,*根据地址取出地址 指向的值。

4. new make函数

在 Go 语言中对于引用类型的变量,我们在使用 的时候不仅要声明它,还要为它分配内存空间,否则我们的值就没办法存储。而对于值类型 的声明不需要分配内存空间,是因为它们在声明的时候已经默认分配好了内存空间。要分配 内存,就引出来今天的 new 和 make。 Go 语言中 new 和 make 是内建的两个函数,主要用 来分配内存。

// new make
	// make针对 slice map channel 而 new 针对 指针
	var userinfo map[string]string
	userinfo["username"] = "张三"
	fmt.Println(userinfo) //panic: assignment to entry in nil map 报错原因就是map是引用数据类型需要make创建
 
	var user = make(map[string]string)
	user["username"] = "张三"
	fmt.Println(user) // map[username:张三]
 
	var f *int
	*f = 100
	fmt.Println(*f) // panic: runtime error: invalid memory address or nil pointer dereference 报错原因一致
 
	var g *int
	g = new(int)
	*g = 100
	fmt.Println(*g) // 100 主要原因是要分配一个内存地址

new 与 make 的区别:

1. 二者都是用来做内存分配的。

2. make 只用于 slice、map 以及 channel 的初始化,返回的还是这三个引用类型本身

3. 而 new 用于类型的内存分配,并且内存对应的值为类型零值,返回的是指向类型的指针。

相关推荐

Mysql和Oracle实现序列自增(oracle创建序列的sql)

Mysql和Oracle实现序列自增/*ORACLE设置自增序列oracle本身不支持如mysql的AUTO_INCREMENT自增方式,我们可以用序列加触发器的形式实现,假如有一个表T_WORKM...

关于Oracle数据库12c 新特性总结(oracle数据库19c与12c)

概述今天主要简单介绍一下Oracle12c的一些新特性,仅供参考。参考:http://docs.oracle.com/database/121/NEWFT/chapter12102.htm#NEWFT...

MySQL CREATE TABLE 简单设计模板交流

推荐用MySQL8.0(2018/4/19发布,开发者说同比5.7快2倍)或同类型以上版本....

mysql学习9:创建数据库(mysql5.5创建数据库)

前言:我也是在学习过程中,不对的地方请谅解showdatabases;#查看数据库表createdatabasename...

MySQL面试题-CREATE TABLE AS 与CREATE TABLE LIKE的区别

执行"CREATETABLE新表ASSELECT*FROM原表;"后,新表与原表的字段一致,但主键、索引不会复制到新表,会把原表的表记录复制到新表。...

Nike Dunk High Volt 和 Bright Spruce 预计将于 12 月推出

在街上看到的PandaDunk的超载可能让一些球鞋迷们望而却步,但Dunk的浪潮仍然强劲,看不到尽头。我们看到的很多版本都是为女性和儿童制作的,这种新配色为后者引入了一种令人耳目一新的新选择,而...

美国多功能舰载雷达及美国海军舰载多功能雷达系统技术介绍

多功能雷达AN/SPY-1的特性和技术能力,该雷达已经在美国海军服役了30多年,其修改-AN/SPY-1A、AN/SPY-1B(V)、AN/SPY-1D、AN/SPY-1D(V),以及雷神...

汽车音响怎么玩,安装技术知识(汽车音响怎么玩,安装技术知识视频)

全面分析汽车音响使用或安装技术常识一:主机是大多数人最熟习的音响器材,有关主机的各种性能及规格,也是耳熟能详的事,以下是一些在使用或安装时,比较需要注意的事项:LOUDNESS:几年前的主机,此按...

【推荐】ProAc Response系列扬声器逐个看

有考牌(公认好声音)扬声器之称ProAcTablette小音箱,相信不少音响发烧友都曾经,或者现在依然持有,正当大家逐渐掌握Tablette的摆位设定与器材配搭之后,下一步就会考虑升级至表现更全...

#本站首晒# 漂洋过海来看你 — BLACK&DECKER 百得 BDH2000L无绳吸尘器 开箱

作者:初吻给了烟sco混迹张大妈时日不短了,手没少剁。家里有了汪星人,吸尘器使用频率相当高,偶尔零星打扫用卧式的实在麻烦(汪星人:你这分明是找借口,我掉毛是满屋子都有,铲屎君都是用卧式满屋子吸的,你...

专题|一个品牌一件产品(英国篇)之Quested(罗杰之声)

Quested(罗杰之声)代表产品:Q212FS品牌介绍Quested(罗杰之声)是录音监听领域的传奇品牌,由英国录音师RogerQuested于1985年创立。在成立Quested之前,Roger...

常用半导体中英对照表(建议收藏)(半导体英文术语)

作为一个源自国外的技术,半导体产业涉及许多英文术语。加之从业者很多都有海外经历或习惯于用英文表达相关技术和工艺节点,这就导致许多英文术语翻译成中文后,仍有不少人照应不上或不知如何翻译。为此,我们整理了...

Fyne Audio F502SP 2.5音路低音反射式落地音箱评测

FyneAudio的F500系列,有新成员了!不过,新成员不是新的款式,却是根据原有款式提出特别版。特别版产品在原有型号后标注了SP字样,意思是SpecialProduction。Fyne一共推出...

有哪些免费的内存数据库(In-Memory Database)

以下是一些常见的免费的内存数据库:1.Redis:Redis是一个开源的内存数据库,它支持多种数据结构,如字符串、哈希表、列表、集合和有序集合。Redis提供了快速的读写操作,并且支持持久化数据到磁...

RazorSQL Mac版(SQL数据库查询工具)

RazorSQLMac特别版是一款看似简单实则功能非常出色的SQL数据库查询、编辑、浏览和管理工具。RazorSQLformac特别版可以帮你管理多个数据库,支持主流的30多种数据库,包括Ca...

取消回复欢迎 发表评论: