我一直从事服务器后端系统开发快 10 年了,高并发分布式是互联网应用的基础,工作中先后使用过C#、Java、Go 等语言。当前工作需要把平台迁移到 Go,从零开始构建基础设施框架,在基础设施框架上开发各种业务系统。在迁移过程中逐步自研了一套功能完善的基础框架,同时也对语言的一些特性有了更深入的了解,所以便有了这个专栏。
这个专栏的目的是如何把一门语言学精通了,什么叫精通,就是该会的东西都会了,让读者对语言有更全面更深入的认识,让读者掌握怎么利用逆向方法推导某种细节带到其他语言学习中去,而不是仅仅是学一门,吃力一门。
你可以把一门语言看成是一个长期项目,通过这个长期项目来锻炼提升自己。比如 Go,从代码实现上,主要有类型系统设计,函数执行,内置的数据结构,对象系统设计,运行时,标准库,工具链等这些方面,但是这些方面仅仅看文档就能深入理解吗?
脱离 Go 文档之外,学习 Go 进阶会遇到哪些问题:
- 编程语言对线程有哪些抽象模型?
- 上下文切换对性能有哪些影响?
- Go 语言如何管理内存?
- 垃圾回收如何实现并发清理和并发标记?
- Go 语言 PMG 模型有什么优缺点?
- 并发和并行有什么不同? <