1.11 flag 库
明天介绍一个库 flag,命令行程序罕用,用来承受参数的。
var (
intflag int
boolflag bool
stringflag string
)
func init() {flag.IntVar(&intflag, "intflag", 0, "int flag value")
flag.BoolVar(&boolflag, "boolflag", false, "bool flag value")
flag.StringVar(&stringflag, "stringflag", "default", "string flag value")
}
func main() {flag.Parse()
fmt.Println("int flag:", intflag)
fmt.Println("bool flag:", boolflag)
fmt.Println("string flag:", stringflag)
}
用法
./main.exe -intflag 12 -boolflag 1 -stringflag test
接管了三个参数,输入:
int flag: 12
bool flag: true
string flag: test
init
函数里写了参数的默认值,参数输出帮忙。
作业
- 自行钻研如何输入参数帮忙
-
抢答 boolflag 的默认值是什么
1.12 viper 库
明天要介绍的是 viper 一个罕用的配置读取包。github.com/spf13/viper
,它反对:
- 设置默认值
- 从
JSON
、TOML
、YAML
、HCL
、envfile
和Java
属性配置文件读取 - 实时监控和从新读取配置文件(可选)
- 从环境变量、命令行参数、缓冲区读取
- 从近程配置零碎(
etcd
或Consul
)读取,并察看变动 - 显式配置值
简略来说只有三步,指定配置文件,初始化,应用,大家下来本人理解。
宋跑跑:viper
好用 然而目前不反对环境变量数组解析。
Mike: uber 出了不少好货色,果然还是要有业务积淀,能力造出好用的轮子。
1.13 协程池
大家感觉 Go 有必要有协程池吗?
学过 GMP
和了解 Goroutine
的同学应该理解其耗费资源极低,所以实际上即用即销毁,没必要弄。
有些人会把池子拿来做 限流、限度并发 等操作,这个时候是须要的,比方 超高并发低延时 的case
,比方做网关,可能同时会启动很多 Go 程但又同时在运行的状况。
网上有用 waitgroup
+channel
做了一个,实际上是利用 chan 的大小加上 context 的来管制的
源码 https://github.com/remeh/sizedwaitgroup
援用知乎问题:https://www.zhihu.com/question/302981392
外围代码是是上面的,大家本人钻研,有不懂的问我
s.AddWithContext(context.Background())
// 还有
select {case <-ctx.Done():
return ctx.Err()
case s.current <- struct{}{}:
break
}
1.16 异样解决
在 Go
语言里是没有 try catch
的概念的,因为 try catch
会耗费更多资源,而且不论从 try
外面哪个中央跳进去,都是对代码失常构造的一种毁坏。
所以 Go
语言的设计思维中主张: 如果一个函数可能出现异常,那么应该把异样作为返回值,没有异样就返回 nil
。
每次调用可能出现异常的函数时,都应该被动进行查看,并做出反馈,这种 if
语句术语叫卫述语句。
所以异样应该总是把握在咱们的手上,保障每次操作产生的影响达到最小,保障程序即便局部中央呈现问题,也不会影响整个程序的运行,及时的解决异样,这样就能够加重下层解决异样的压力。
同时也不要让未知的异样使你的程序解体。
PS: panic recover
语句文中没有说,只能在同一个 Go
程中进行 recover
,且在defer
中应用 recover
时不得用调用函数的形式把 recover
对立抽出来共用。
1.17 Go 能做什么事件
明天想和大家 Go 能做什么事件。
我集体认为 Go
实际上不适宜专门做 web
,因为Go
的 次要应用领域就是云原生,kubernetes
、prometheus
都是利用了 Go
作为开发语言。特地是 kubernetes operator
,其对kubernetes
的扩大,使得 Go
在云原生大行其道。
javaer
把它当 java
写,pythoner
拿他当 py
写,十个人有十种写法。每个人的了解都不同。
网友的想法云原生中比拟重要的几点:
- 微服务、容器、继续交付,在 Java 体系中体现得其实很好,然而资源占用管制下面还是有余(指那种没有通过非凡优化的);
PHP
又压根没往这方向倒退;.Net
开源的工夫太晚;- 这时候一个主打性能、资源占用少、“工程标准且简略”的语言进去,拉了几个大佬背书,还是
google
亲儿子,所以就推起来了。 - 另外
golang
也的确不负众望,搭建起来了一些生态环境,比方容器docker
和容器编排的止境K8S
; - 生态一旦造成,如果想入局,那真得融入了。
就传统 B/S
或者 C/S
的web
开发来说,其实 Go
一点也不爽,但一但围绕云原生搞一些周边,不论爽不爽,都要沾点Go
。
Go
的益处是入门简略,做业务需要的状况下,不波及太多高级语法。Go
倒退到当初,越来越多的开发者一直的生产工具,框架,百花齐放,所以咱们应该放弃开源激情,把握和理解这些框架以备将来使用方便,工作提效。
过年了,Go 技术群的每日一 Go 暂停分享,等年后复原啦~!年后复原后每周发表每日一 Go。第一期期刊就到这里啦~!
本文由 mdnice 多平台公布