最近非常不幸地遭到了裁员,除了未来生计还没着落外,每个月为了维持小A正常运行那小一千块的各种支出也成了一大难题。尽管时不时也有用户打赏,但那只是杯水车薪。考虑到短时间内没有任何盈利的希望,不能开源只能节流了。未来几个月我会把小A的后端彻底升级,达到多快好省的效果,并且我会把这个过程记录下来,分享给有需要的朋友同时做自我提升。经常有学编程的同学问我各种问题,相信这几篇文章能一次解答大部分。
首先说一下背景
目前小A的后端API使用的是ASP.NET Framework。这个框架老了,老得微软自己都放弃了。性能一般而且只能运行在Windows Server上,价格翻倍,所以必须换掉。
编程语言和框架
ASP.NET Core + C#
微软翻盘之作,网上各种吹捧,性能优异。我之前使用ASP.NET,所以上手Core毫无压力。但它实在太臃肿了!微软似乎很热衷做加法,C#语言各种关键词让我崩溃。比如IList, IEnumberable, ICollection, ArrayList; class, struct, record; byref, out; 而且C#每年一次大更新,累!
Flask + Python
Python这几年一直保持着最受欢迎语言的美誉。我不太喜欢它的语法,因为和C底语言大相径庭。我怀疑很多人用Python主要一是Python语言的确对初学者更友好,学校里教的多;二是由于学校教的多,在网上提问的学生多,所以感觉用的人多。机器学习为何偏爱Python一直是个疑问。我使用过Flask+Pytorch做小A的NLP接口,目前看这是NLP接口最好的组合了。Python相对性能不行。
Express.js + TypeScript
我没有使用过Express.js,但是使用过TypeScript做前端项目(Angular)。个人还是很喜欢TypeScript的。但是TypeScript不能直接使用,必须转译成JavaScript,JavaScript性能可想而知。
Swift + ?
常年开发iOS应用的原因,非常熟悉Swift语言,性能应该不错,语法感觉和C#相似,没那么臃肿。比较奇怪的时Swift语言虽然也开源,但除了开发iOS/MacOS外似乎无人问津。
既然都有问题,那就使用最熟悉的ASP.NET Core好了。。。吧?
妥协?这辈子都不妥协!
早些时候我几个同事推荐我使用Golang,于是我折腾几天后确定用它了。不得不说Golang满足我了几乎全部需求:
1. 性能非常好,好于C#
2. 语法非常简单,关键字比C#少的多
3. 有大公司支持,成上升趋势
当然也有些我还不习惯的地方
1. package命名。使用ASP时我习惯了把一个大的Solution分成几个Project,每个Project里包含很多文件夹和副文件夹。C# namespace很好的支持了以文件夹命名,但是Golang对多文件夹不太友好,导致我需要把很多以前分开的文件放入同一个文件夹中
2. Pointer也许对新手不友好。我上一次使用Pointer还是在用Objective C写iOS app的年代,至少得有8年前了。如何正确使用* &需要时间的洗礼。在主流编程语言都放弃Pointer的年代依然大量使用也许有设计者自己的考量。
必须说的一点
Golang的interface和多数其他语言的不一样,任何的struct只要有某个interface中全部的func就被算成是继承了该interface。一开始我不太能理解,后来恍然大悟。这样做解决了C#只能继承一个interface的问题,应该还有其他的好处我会慢慢发觉。
API框架我使用了Gin,目前最受欢迎的Web框架。
写这篇文章的时候我的API后端已经完成了30%左右,不得不说我庆幸最终坚持使用了Golang而不是C#。人生就是不停地学习和推翻既有认知,不得意的阶段也许提升自己才是唯一的出路。
下一篇我会谈数据库和项目结构(Project Structure)。Project Structure是任何项目中最重要的却又经常被人忽略的一个环节,值得用一整篇来详解。
网友评论