一年开发做过的错事,踩过的坑

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了一年开发做过的错事,踩过的坑相关的知识,希望对你有一定的参考价值。


 

 这篇文章,作为自己开发一年的小总结。

 因为一些问题造成了很多不必要的时间的浪费。

 这篇文章比较适合,没有实际开发经验的人看。同样适合一年左右经验的人看。也欢迎有经验的可以给我提出宝贵的意见。

 

# # 代码整洁的相关问题

  这一块,确实中间也浪费了不少的时间,中间领导专门拿着阿里开发规范,来扣我们的代码,一个细节一个细节的去让我们改。我倒还是之前本来就熟悉阿里开发手册。还算比较规范。

  建议还是看看阿里的《阿里开发手册》,另外建议去读《代码整洁之道》和《重构:改善既有代码》这两本书。然后开始知道整洁的代码应该是什么样的。严格的要求自己,做到对自己的每一行代码负责。建议读一些设计模式之类的数据另外建议读一下spring 的源码,这个可以学到很多的设计思想。对我们设计系统,解决问题有很大的帮助,可从里边学习到如何去增加扩展性。

  最后如果你觉得自己的代码ok了,可以下载一下阿里的开发规约的插件。用来检查自己的代码,只需要扫描一遍,就知道哪里有问题。然后去改。

  这一块开始从起手开发就装上插件,每天提交的代码,自己检查。可以节省时间在重新整理代码上。说白了就是一遍过。

 

# #  第二个问题是 工具类封装的问题

  所谓的工具类,真的就是公用的代码。本来说好的不重复造轮子,坏就坏在我们不知道轮子在哪里,其实这就是技术视野的问题。不知道有轮子,所以我们自己造轮子,所以浪费时间。所以要加班要996.

  最痛苦的还不是重复造轮子的问题,还有一个轮子在项目里边被造了很多次的情况,经理一审查代码,直接吐了,抢救完经历,解接下来就得抢救我们的代码了,协调一下跟你造了重复轮子的同事,要不咱们统一用我的工具类?每个人都觉得自己写的是最好的,担心用了别人的要重新测试,害怕出现问题。

  这个来来回回的改,加上造轮子与测试,花费很多时间,这些时间都是 996 挤出来的,本来不用加班。

  这里不多啰嗦了,一步到位,我给大家推荐一个 好用的轮子。 叫做 hutool 的工具类,及其方便,pom里边直接引入就行了,自己看看里边都有什么轮子就好了。

  官网:​​https://hutool.cn/​​ 

  别看什么其他别人写的介绍文档了,直接去官网上看吧。省事,还准确。

 

# # 第三个问题是使用统一配置中心的问题 

  我们是使用的 Apollo,携程的统一配置中心。一开始刚进项目,不懂什么是统一配置,刚从学校出来,谁听说过呀。关键,我们的项目打好,引入了 Apollo的依赖,并没有去从 Apollo上读取配置信息。读的本地的配置,结果项目跑起来,就时不时的去拉取配置。

  我觉得这个问题,就狠一点,一步到位,要么直接从一开始就用统一配置中心。最后省事,但是在开发过程中,可能会痛苦一点,一不小心,别人给你的配置误删了,估计就得找很大一会尔错误,才知道配置没了。 这么说起来,也可以一开始都用本地的配置,不要引入Apollo,最后都测试没问题了,统一引进来。这个也耽误了比较长的时间。

 

# #  第四个问题就是分库分表的问题

  我们的项目是一开始在单库上做开发,都开发完,测试完了,又要加分库分表。

  我们用的 sharding 做的分库分表,sharding 天生就不支持一些sql,比如集合函数需要起一个别名,比如 distinct去重操作,几乎不支持。这些也没人给我们说,就让我们自己解决,自己测试。这太浪费时间了。

  关于这个问题,我觉得也是一步到位,从项目开始就去考虑要不要进行分库分表,这样省去了重复测试的问题,会节省很多很多的时间。另外就是一定要有人出来把sharding 相关的坑,就给大家说明白,免得重复跳坑,浪费时间。

  sharding 说是对开发人员来说无感的,其实并不是,需要注意蛮多坑。具体的还是看官方文档。

  

# # 自身问题

  当然了,自己本身也是有问题的,比方一上来的时候,因为环境问题会耽误很长是时间。还是多遇见一些问题就好了。

以上是关于一年开发做过的错事,踩过的坑的主要内容,如果未能解决你的问题,请参考以下文章

微信小程序踩过的坑

[转] 那些在使用webpack时踩过的坑

转:Flutter开发中踩过的坑

做项目管理踩过的坑

微信小程序开发过程中踩过的坑集合,没有解决不了的错误,只有踩不完的坑

那些年我们一起踩过的坑