go语言做TODO项目 go语言编程之旅一起用go做项目

go语言可以做什么1、服务器编程:以前你如果使用C或者C++做的那些事情,用Go来做很合适,例如处理日志、数据打包、虚拟机处理、文件系统等 。
2、分布式系统、数据库代理器、中间件:例如Etcd 。
3、网络编程:这一块目前应用最广,包括Web应用、API应用、下载应用,而且Go内置的net/http包基本上把我们平常用到的网络功能都实现了 。
4、开发云平台:目前国外很多云平台在采用Go开发,我们所熟知的七牛云、华为云等等都有使用Go进行开发并且开源的成型的产品 。
5、区块链:目前有一种说法,技术从业人员把Go语言称作为区块链行业的开发语言 。如果大家学习区块链技术的话,就会发现现在有很多很多的区块链的系统和应用都是采用Go进行开发的 , 比如ehtereum是目前知名度最大的公链,再比如fabric是目前最知名的联盟链,两者都有go语言的版本,且go-ehtereum还是以太坊官方推荐的版本 。
自1.0版发布以来,go语言引起了众多开发者的关注,并得到了广泛的应用 。go语言简单、高效、并发的特点吸引了许多传统的语言开发人员,其数量也在不断增加 。
使用 Go 语言开发的开源项目非常多 。早期的 Go 语言开源项目只是通过 Go 语言与传统项目进行C语言库绑定实现,例如 Qt、Sqlite 等 。
后期的很多项目都使用 Go 语言进行重新原生实现,这个过程相对于其他语言要简单一些,这也促成了大量使用 Go 语言原生开发项目的出现 。
Go语言之Contextgolang在1.6.2的时候还没有自己的context,在1.7的版本中就把golang.org/x/net/context包被加入到了官方的库中 。中文译作“上下文”,它主要包含了goroutine 的运行状态、环境等信息 。
context 主要用来在 goroutine 之间传递上下文信息,包括:同步信号、超时时间、截止时间、请求相关值等 。
该接口定义了四个需要实现的方法:
如果有个网络请求Request,然后这个请求又可以开启多个goroutine做一些事情,当这个网络请求出现异常和超时时,这个请求结束了,这时候就可以通过context来跟踪这些goroutine,并且通过Context来取消他们,然后系统才可回收所占用的资源 。
为了更方便的创建Context,包里头定义了Background来作为所有Context的根,它是一个emptyCtx的实例 。
Background返回一个非空的Context 。它永远不会被取消 。它通常用来初始化和测试使用,作为一个顶层的context , 也就是说一般我们创建的context都是基于Background 。
TODO返回一个非空的Context 。当不清楚要使用哪个上下文的时候可以使用TODO 。
他们两个本质上都是emptyCtx结构体类型 , 是一个不可取消,没有设置截止时间,没有携带任何值的Context 。
有了如上的根Context,那么是如何衍生更多的子Context的呢?这就要靠context包为我们提供的With系列的函数了 。
通过这些函数,就创建了一颗Context树,树的每个节点都可以有任意多个子节点,节点层级可以有任意多个 。
WithCancel函数,最常用的派生 context 方法 。该方法接受一个父 context 。父 context 可以是一个 background context 或其他 context 。
WithDeadline函数 , 该方法会创建一个带有 deadline 的 context 。当 deadline 到期后,该 context 以及该 context 的可能子 context 会受到 cancel 通知 。另外,如果 deadline 前调用 cancelFunc 则会提前发送取消通知 。
WithTimeout和WithDeadline基本上一样 , 这个表示是超时自动取消,是多少时间后自动取消Context的意思 。
WithValue函数和取消Context无关,它是为了生成一个绑定了一个键值对数据的Context,这个绑定的数据可以通过Context.Value方法访问到 , 一般我们想要通过上下文来传递数据时,可以通过这个方法,如我们需要tarce追踪系统调用栈的时候 。

推荐阅读