1、很多人都在问我,到底该不该学习Go语言。直接给你答案吧,你也不信。所以,在正式回答之前,我们还是先说说,到底怎么判断一门语言是不是有前景。
2、左耳朵耗子之前曾经分享过他的经验,看一个技术能不能火起来,主要从三个角度,第一,有没有雄厚的资金支持。第二,有没有一个活跃的社区。第三,有没有杀手级的应用。这个逻辑对不对,你可以用Java以及另外一门没有火的技术来印证下。
3、就拿Go来说,他背靠Google公司,社区非常活跃,并且有Docker、Kubernetes这样的杀手级应用。现在,我们已经看到,Go是云计算时代的首选编程语言,并且,我还可以很确定的说,它正在成为下一个企业级编程语言。
4、Go语言是字节跳动内部使用最多的编程语言。为啥?因为字节跳动更看重效率,Go语言上手简单,学习难度低。另外, Goroutine 和 Channel 这两个神器可以很好解决并发和异步编程的问题。它是新一代的编程语言。
5、如果你的第一语言是PHP,或者Python,或者C#,并且职位是后端工程师,那我还是建议你学学Go。不是鼓吹Go,是我觉得这是趋势,我们不管是写程序,还是做其他事情,都应该顺应时代。
6、云原生是趋势,大部分云原生项目都是用Go写的。如果你想研究Kubernetes,不懂Go可以吗?Java那个赛道很拥挤,如果你想脱颖而出,为什么不试试Go呢?
7、到这里,你会说,语言没有好坏,只有合不合适。是这个逻辑,但是,技术的发展总是一浪接一浪,Go诞生的时间比较晚,就语言本身,他很多设计理念都是超前的,它代表着先进的生产力。
8、我知道,你还会反驳,Java还很老了,可人家现在还是企业级编程语言的主力军。是的,结论没错。但你要知道,Java与其他语言竞争,底气从来不在于语法、类库有多么先进好用,而是来自它庞大的用户群和极其成熟的软件生态,这在朝夕之间难以撼动。这是周志明老师说的。
9、但是,Java也在变,因为如果不变,它由强大生态所构建的护城河终究会消耗殆尽。所以,类似Project Leyden、Project Valhalla之类的项目都是在推动Java往类似Go这样的原生语言的方向变。
10、现在主流的判断是Go语言做中间层、PaaS层的项目,Java做业务层,Rust/C++做系统层。不信的话,你可以去看看最新的一些主流开源项目,是不是这个逻辑。
11、不管怎么样,如果你是一名后端工程师,我还是建议你学学Go,不管是从换工作的角度,还是从个人发展的角度。不信的话,你去招聘网站搜搜Go工程师的待遇吧,那个不会骗人。
虽然都说 Go 上手容易,但是想要真正的会使用 Go 语言进行项目的编写,就没有那么容易了。因为大部分人在学习和使用 Go 语言 的过程中,都遇到过这么几个的困境:
一看就会,一写就懵;书籍或别人的代码基本能看懂,但自己写项目时却不知道如何下手;
貌似都懂,面试就露馅;只会简单使用,不知道如何深入了解、如何进阶;
工程化实践经验为 0 ;只会基于别人的框架填代码,不会自己进行工程化;搬砖似乎永远没有竞争力;
说实话,这些问题我自己也遇到过。因为我们大多数人对于 Go 的学习可能仅限于语法,却不清楚它背后的设计原理,没有亲手做过项目。
现在机会来了,极客时间联合资深Go 工程师毛剑重磅出品 ,3 小时带你入门 Go 工程化。
挑战 3 小时入门 Go 工程化!
《攻克 Go 语言 error 处理难题》
揭秘 Go error 类型背后的设计逻辑
探索正确使用 error 类型的姿势
Go 1.13中 error 相关 API 的使用
《特定情况下 errgroup 的实现原理源码解析》
使用 goroutine 进行并行数据访问正确姿势
并发模式和 errgroup 和 worker 模式
并发模式的最佳实践
学完后你将收获
02
理解 Go 语言 error 类型设计基本逻辑
掌握正确使用 error 类型的方式和原则
能够在项目中写出符合 Go 语言规范的 error 处理代码
毛剑
资深 Go 工程师,某一线互联网公司技术总监。
毛剑有近十年的服务端研发经验,他擅长高性能、高可用的服务端研发。毛剑是忠实的 Go 语言粉丝,也是一名 Go 语言老手,他曾在 GitHub 上开源了几个基于 Go 语言的项目,如果你想了解他的技术实力,可以点进去看看,毕竟,Talk is cheap,Show you the code。
另外,毛剑作为嘉宾,也在 QCon、ArchSummit、GopherChina 等业界知名会议上做过 Go 相关的技术干货分享。
如何 0 元学?
长按或扫码添加学习助理即可领取课程
仅 500 个名额,扫码立即加入👇
本文分享自微信公众号 - 老孟Flutter(lao_meng_qd)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。