检查程序的执行路径和当前状态是非常有用的调试手段。核心文件(core file)包含了一个运行进程的内存转储和状态。它主要是用来作为事后调试程序用的。它也可以被用来查看一个运行中的程序的状态。这两个使用场景使调试文件转储成为一个非常好的诊断手段。我们可以用这个方法来做事后诊断和分析线上的服务(production services)。本文介绍调试 Go 语言的 Core Dumps。 我要晨读
剖析使Go语言高效的5个特性(5/5): Goroutine的栈管理。这是高效特性的最后一讲。这些特性个个都很有效,他们之间还相互依赖。比如,如果没有了可衍生的栈,运行环境将多个goroutine复用到线程上面就不会很有效。内联在把多个小函数合并成大函数的时候也避免了栈大小的检查开销。逃逸分析用栈代替堆来存储局部变量,这样也减少来垃圾回收机制的压力。逃逸分析还提升了缓存的性能(cache locality)。没有可衍生的栈,逃逸分析又会对栈造成很大的压力。 我要晨读
剖析使Go语言高效的5个特性(4/5): Goroutines。本文是 David 在 2014 年参加日本东京的 Gocon 会议的演讲的中文翻译。虽然时间有点久,但相信 David 大神的讲解,会让你收益颇多。Go语言有 goroutines。它们是Go语言里并发编程的基石。 我要晨读
剖析使Go语言高效的5个特性(3):垃圾回收机制。本文是 David 在 2014 年参加日本东京的 Gocon 会议的演讲的中文翻译。虽然时间有点久,但相信 David 大神的讲解,会让你收益颇多。本篇讲解垃圾回收机制。 我要晨读
剖析使Go语言高效的5个特性(2):函数调用不是免费的。本文是 David 在 2014 年参加日本东京的 Gocon 会议的演讲的中文翻译。虽然时间有点久,但相信 David 大神的讲解,会让你收益颇多。本篇讲解函数调用相关特性。 我要晨读
剖析使Go语言高效的5个特性(1):变量的处理和存储。本文是 David 在 2014 年参加日本东京的 Gocon 会议的演讲的中文翻译。虽然时间有点久,但相信 David 大神的讲解,会让你收益颇多。 我要晨读
goroutine stack多大呢?是固定的还是动态变化的呢?stack动态变化的话,什么时候扩容和缩容呢?如何实现的呢?对服务有什么影响吗?如何排查栈扩容缩容带来的问题呢?本文聊一聊 goroutine stack。 我要晨读
和大多数计算机语言一样,Go type 默认包含常用的基础数据类型,boolean,numeric and string,这些类型称为 pre-declarered types,这些基础的数据又可以进一步构成更复杂的类型 array,struct,map,slice,channel 等。Type 可以是带名称和不带名称的,称之为 named type 和 unnamed type。 我要晨读
Go语言的性能可以做到非常好,但是一些标准库的性能很可能会拖后腿,比如regexp和encoding/json。如果在性能要求较高的场合使用,要根据实际情况做相应优化。on-cpu/off-cpu火焰图的使用是程序性能分析的利器,往往一针见血。虽然生成一张火焰图比较繁琐(尤其是off-cpu图),但绝对值得拥有! 我要晨读
Go 1.7,testing 包在 T 和 B 类型上引入了一个 Run 方法,允许创建子测试和子基准测试。子测试和子基准测试的引入可以更好地处理故障(failures),细化控制从命令行运行的测试,并行控制,并且经常会使代码更简单、更易于维护。本文介绍使用方法。 我要晨读
日志用来记录用户操作、系统运行状态等,是一个系统的重要组成部分。然而,由于日志通常不属于系统的核心功能,所以常常不被团队成员所重视。对于一些简单的小程序,可能并不需要在如何记录日志的问题上花费太多精力。但是对于作为基础平台为很多产品提供服务的后端程序,就必须要考虑如何依靠良好的日志来保证系统可靠的运行了。 我要晨读
Go应该添加为类型创建替代等效名称的能力,以便在代码库重构期间渐进代码修复。本文解释了对于这种能力的需求,以及没有它对于今天的大型Go代码库的影响。本文还探讨了一些潜在的解决方案,包括在开发(但没有包含在)Go1.8中提出的别名功能。然而,本文不是任何具体解决方案的提案。相反,它旨在作为Go社区讨论Go 1.9中应该包含哪些解决方案的开始。文章较长,但绝对值得一读。 我要晨读
一直以来,我对修饰器这种编程模式情有独钟,之前写过Python的,现在写篇Go相关的。不过,Go 语言的“糖”不多,而且又是强类型的静态无虚拟机的语言,所以,很难做到像Java和Python那样的优雅。当然,如果你知道有更多的写法,请你一定告诉我。 我要晨读
从小案例学习Go语言,知识点包括:使用github.com/tealeg/xlsx包读取xlsx文件;使用regexp包实现正则表达式判断;使用net/smtp包发送电子邮件;使用交叉编译命令生成不同系统上的可执行文件。 我要晨读
【Go语言内幕系列】本文是 Golang 内部机制探索系列博客的后续。这个系列博客的目的是探索 Go 启动过程,这个过程也是理解 Go 运行时(runtime)的关键之处。本文中我们将一起去看看启动过程的第二个部分,分析参数是怎么被初始化的及其中有哪些函数调用等等。 我要晨读
【Go语言内幕系列】启动过程是理解 Go 语言运行时工作原理的关键。如果你想继续深入了解 Go,那么分析启动过程就非常重要。因此第五部分就着重讲解 Go 运行时,特别是 Go 程序的启动过程。 我要晨读
【Go语言内幕系列】今天,我们来看一下 Func 结构体,还会讨论一些关于 Go 垃圾回收的一些细节。Go语言内幕(4):目标文件和函数元数据。 我要晨读
【Go语言内幕系列】本文将会讨论关于 Go 链接器、目标文件(object file)以及重定位(relocation)相关的内容。为什么要关注这些东西呢?如果你想学习任何一个大项目的内部机制,那么你首先要做的一件事就是学会将其分割成不同的部件或者模块。接下来,你需要搞懂这些模块向外提供的接口。在 Go 中,编译器、链接器与运行时就是这样的高层次模块。编译器与链接器之间的接口就是目标文件,所以我们今天就从目标文件开始。 我要晨读
【Go语言内幕系列】当你通过接口引用使用一个变量时,你知道 Go 运行时到底做了哪些工作吗?这个问题并不容易回答。这是因为在 Go 中,一个类型实现了一个接口,但是这个类型并没有包含任何对这个接口的引用。在这里,让我们更加深入地探索 Go 编译器:创建一个简单的 Go 程序来看一下 Go 内部在类型转换时到底做了哪些工作。通过这个例子,我会解释结点树是如何生成并被使用的。同样地,你也可以将这篇博客的知识应用到其它 Go 编译器特征的研究中。 我要晨读