关于程序员:一期每日一GO群分享flagviper协程池异常处理

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函数里写了参数的默认值,参数输出帮忙。

作业

  1. 自行钻研如何输入参数帮忙
  2. 抢答boolflag的默认值是什么

    1.12 viper库

明天要介绍的是viper一个罕用的配置读取包。github.com/spf13/viper,它反对:

  • 设置默认值
  • JSONTOMLYAMLHCLenvfileJava 属性配置文件读取
  • 实时监控和从新读取配置文件(可选)
  • 从环境变量、命令行参数、缓冲区读取
  • 从近程配置零碎(etcdConsul)读取,并察看变动
  • 显式配置值

简略来说只有三步,指定配置文件,初始化,应用,大家下来本人理解。

宋跑跑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的 次要应用领域就是云原生,kubernetesprometheus都是利用了Go作为开发语言。特地是kubernetes operator,其对kubernetes的扩大,使得Go在云原生大行其道。

javaer把它当java写,pythoner拿他当py写,十个人有十种写法。每个人的了解都不同。

网友的想法云原生中比拟重要的几点:

  • 微服务、容器、继续交付,在Java体系中体现得其实很好,然而资源占用管制下面还是有余(指那种没有通过非凡优化的);
  • PHP又压根没往这方向倒退;.Net开源的工夫太晚;
  • 这时候一个主打性能、资源占用少、“工程标准且简略”的语言进去,拉了几个大佬背书,还是google亲儿子,所以就推起来了。
  • 另外golang也的确不负众望,搭建起来了一些生态环境,比方容器docker和容器编排的止境K8S
  • 生态一旦造成,如果想入局,那真得融入了。

就传统B/S或者C/Sweb开发来说,其实Go一点也不爽,但一但围绕云原生搞一些周边,不论爽不爽,都要沾点Go

Go的益处是入门简略,做业务需要的状况下,不波及太多高级语法。
Go倒退到当初,越来越多的开发者一直的生产工具,框架,百花齐放,所以咱们应该放弃开源激情,把握和理解这些框架以备将来使用方便,工作提效。

过年了,Go技术群的每日一Go暂停分享,等年后复原啦~!年后复原后每周发表每日一Go。第一期期刊就到这里啦~!

本文由mdnice多平台公布

【腾讯云】轻量 2核2G4M,首年65元

阿里云限时活动-云数据库 RDS MySQL  1核2G配置 1.88/月 速抢

本文由乐趣区整理发布,转载请注明出处,谢谢。

您可能还喜欢...

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注

此站点使用Akismet来减少垃圾评论。了解我们如何处理您的评论数据