前端成长01 高级程序员和普通程序员有哪些区别?

原文地址:高级程序员和普通程序员有哪些区别? - 暗灭的回答 - 知乎https://www.zhihu.com/question/33578621/answer/451931102

先不说高级。就只说初级程序员经常容易犯的错误,把这些错误改正了,你离中级就不远了。

初级程序员经常犯的错误集锦

1.  命名不规范

2. 日志不规范

3. 拒绝写接口和假数据

4. 不写单元测试

5. 盲目集成

6. 逻辑不清

7. 不做方案

8. 不关注性能

9. 害怕重构

10. 做出来就好,不考虑优雅的方案

11. 不考虑未来需求的变化

12. 遇到问题的时候不会试错

13. 不会写伪代码

14. 不做数据量的预估

15. 提交代码不规范

16. 不喜欢打Tag

17. 不遵守发布流程

18. 不知道Bug修复的优先级

19. 总喜欢手动修改线上代码

20. 不做数据备份

21. 不做自测

22. 不尽力模仿真实数据,测试数据很随意

23. 不抽取公共代码

24. 不认真听需求讲解

25. 不看验收标准

26. 不主动推进项目进度

27. 遇到难题不主动反馈

一 命名不规范

命名很随意,当时写代码特别High,什么奇奇怪怪的命名都有的:xiaonaigou,xxxx,j1,jl,llst.

完全意识不到全名规范的价值和意义。


二 日志不规范

日志?那是什么鬼东西,能吃么?

曾经有一个从文思海辉出来的小伙伴,三年后端工程师经验,出了问题不知道怎么解决。

只好重启。

找我来协助,问他,怎么错了?

不知道。

日志呢?

没有。

晕,那怎么解决问题,神仙也搞不定啊。

后来才知道,他们解决问题都是本地改代码然后直接部署,重新访问看错误消失没,没有消失就继续在本地改源码。


三 拒绝写接口和假数据

一个菜鸡不可怕,可怕的是菜鸡遇到菜鸡。曾经有一个项目中的两个菜鸡,一个前端一个后端,他们很欢快的调接口,根本不写文档

,两个人效率特别高。

直到有一天,发现项目可能做不完了,需要另外两个前端菜鸡协助一下。

新来的两个菜鸡要获取后端的数据,不知道接口的Url地址,不知道Get还是Post,不知道发送的参数和返回值。就这样写!

我压根没想到可以这么写代码,两个菜鸡很开心!拍手称快:通了,通了,通了!

我说你们通什么呢?他们说接口终于通了!原来他们两个参考之间的页面,硬生生的一次一次不停的尝试,就这样把接口猜出来了!

这就是编程的乐趣吗?

还有不写假数据。曾经有一个马姓小哥,对赵姓小哥信誓旦旦的说:3天,给我3天时间 ,我把真数据给你。

于是赵姓小哥信以为真。就这样,3天又3天,3天又3天,3天又3天,3天又3天,3天又3天。

整整一个半月,赵姓小哥都没有拿到全部的数据!


四 不写单元测试

确切来说,是不按TDD的方式开发。在现在IDE这么强大的情况下,先写单元测试的习惯,不仅仅是代码的严谨性,也是效率的代名词啊。

可是很多菜鸡理解不了单元测试的价值,没关系,等到代码重构,需求变更的时候,就哭都哭不出来了!

好的单元测试,你的逻辑必然会清楚。


五 先集成,再测试,再放弃

很多时候,菜鸡在引入第三方的库,框架,接口或者是服务的时候,最喜欢的事情就是直接和自己原有的代码集成在一起。

结果 是什么呢?突然间不能用了,跑不起来了,不知道问题出在哪了,根本分不清倒底是第三方的问题还是自己的问题。

好的方法是什么?先跑通官方提供的Demo,再想办法一点一点加上自己的业务。


六 理不清楚逻辑,边做边猜

前端在这里的问题特别多,做支付,不清楚支付的流程,分不清楚定义,总以为前端就是接口处理好数据展示好拉倒。

很多菜鸡都会有这种习惯,这样不好,先把逻辑处理好,弄清楚流程,再去动手才好。


七 不做方案

不做方案代表什么含义呢?就是完全凭直觉行走啊。

跟闭上眼逛窑子一样。

写代码的好习惯应该是先在脑袋里把所有的需求细节过一遍,实现细节拿出来。

上个月就有一个张姓小菜鸡,做一个匿名评论的功能。

基本上没有什么经验,脑子也不好使,给出的方式是什么你们猜得到么?

用户刷新一次就往用户表里插入一条数据,密码默认昵称随机。

不多说了都是泪,我见过太多让人目瞪狗呆的方案了,看着满屏的代码,你怎么帮他调错调优,最好的方式就是全部重写。

做方案的好处太多了。


八 不关注性能

不关注性能也是新人很容易犯的错。什么是性能呢。对后端来说就是TPS和响应时间,对前端来说就是响应时间。

很多新人程序员的习惯就是把东西做出来,然后再优化。

最后就是东西做出来了,优化留给别人了。

对性能的关注也是晋升中级程序员最关键的技能点。在写代码的时候,有经验的工程师已经知道了这个方法这个函数这个功能点的性能怎么样,瓶颈在哪里。


九 害怕重构

“程序员最大的勇气就是看自己三个月之前写的代码。”

其实重构并不应该是在几个月之后重构,最好的方式是实时重构。写一天代码,70%的时间都放到重构上都不过份。

而新人呢,磕磕跘跘的完成一个功能,就跟多米诺骨牌做成的大黄蜂一样,你敢动一下他的代码试试?他会跟你拼命。

你让他自己动一行代码试试?

不重构在某种程度上也意味着你的代码实现无法重塑。


十 做出来就好,不考虑优雅的方案

有个词叫做最佳实践,其实编码规范和最佳实践,是编程功底的重要体现。

优雅方案可以认为是最佳实践的升级版,它和上面说到的不断的重构是相辅相成的。

不好的方案是什么呢?硬编码居多,没有可扩展性,用很丑陋的方式完成了功能。

上次他们去做了一个关于试听课的方案,一个人能试听多少节课,正常的逻辑应该是在用户的表里加一个字段来表示。

需求是写着邀请几个人,可以试听多少节课,所以他们判断试听多少节课就直接在通过邀请人的表里查询去做。

完全没考虑到以后如果我变换了试听课的判断条件怎么办?

实际上这是应该拆解成两部分,一个是试听课的产生条件,这是一个独立的模块,加一个是试听课的确认。

像这种例子太多了,也和不做方案,不考虑扩展性有关系。就是接下来要说的。


十一 不考虑未来需求的变化

工程师的水准,其实可以分成以下几个阶段(马丹我找不到之前在哪个答案里写过了):

面向功能编程

面向性能编程

面向未来编程

工程师拿到需求的第一件事,应该聚集在以下几个问题:

第一 哪些需求是我之前完成过的

第二 哪些需求是有可能变化的

第三 有几种方案,分别支持什么样的需求变化

但是差一点的程序员就考虑不到那么远,一个是对业务不熟悉,判断不出来哪些需求可能会产生变化,一个是对可选的方案掌握的不多,根本就没有什么可选的余地,还有就是没有这种思维习惯,分不清楚哪些是现在要完成的,哪些是未来可能会支持或者是变动的。


十二 遇到问题的时候不会试错

这也是新手常见的问题。很多时候新人会遇到问题,解决不了,去找一个有经验的工程师,这个有经验的工程师呢,大概也未曾遇到这种情况,但是他解决问题的思路清楚啊。

一会儿试试这个,一会儿删删那段代码,很快就跑通了。

解决问题是一个很见功底的技术点,而且是有很多方法论的,之前总结过一些,简单列举过来:

[if !supportLists]1.    [endif]寻找正确的代码

[if !supportLists]2.    [endif]理清楚正确的执行顺序

[if !supportLists]3.    [endif]重现错误

[if !supportLists]4.    [endif]最小化错误产生的场景

[if !supportLists]5.    [endif]修改代码到一个已知的错误类型

等等等。

解决问题就是一个分析推理的过程,而在这里呢,背后的功底就是你知道很多哪些是肯定不会错的小公理,然后再挨个去定位可能产生错误的环节,分解流程是最基础的工作。


十三 不会写伪代码

伪代码是什么呢?就是自然语言啊。其实编程只有三种逻辑控制块,顺序,循环,判断。

所以你只要用自然语言来描述出来,先做什么,再做什么,什么时候循环,什么时候判断,

代码写出来的问题就不大。

这是一个先写伪代码再写细节的过程。你不要上来就开始平铺写代码(我之前讲过优雅代码之道,有兴趣的可以加群听一下,重点讲了怎么写出来优雅代码)。

平铺代码是最菜的方式,好的代码是有结构的,有不同的抽像层级。

第一步,干嘛。

第二步,干嘛。

第三步,干嘛。

先把这个列清楚,这是伪代码的第一级。

然后变成注释,这是第二级。

删掉注释变成函数名,这是第三级。

所以说,好的程序员写代码是不需要注释的,不是说让你把注释删掉,而是让你完成这三步升华的过程。

写的好的代码,命名规范,你看到的真的是一首诗, 是一种编程语言,是在用语言来描述一件功能的完成,这种编程艺术的工业感很爽快,你看那些不爽的代码,简直了。。


十四 不做数据量的预估

后端工程师在前期经常会忽视数据量的大小,没有影成一个好的习惯。

写代码只注重功能,没有一个关于数据量的概念。

这个地方其实还和性能是一致的,在性能上,前后端并没有太大的差别。

推荐的做法是,程序员要对数据很敏感,后端要知道每一个表的规模可能会有多大,当前的系统能支持的数据库表的大小是多大,而前后端都需要知道每一个操作,都分成了哪几个步骤,每一个步骤花费的时间是多少,大概占用的内存是什么样的。

做到这一点其实并不难,难的是养成这种习惯,初级工程师眼里看的是功能和代码,中级工程师眼里看到的是数据和时间。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,884评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,755评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,369评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,799评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,910评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,096评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,159评论 3 411
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,917评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,360评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,673评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,814评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,509评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,156评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,123评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,641评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,728评论 2 351

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,870评论 25 707
  • 用两张图告诉你,为什么你的 App 会卡顿? - Android - 掘金 Cover 有什么料? 从这篇文章中你...
    hw1212阅读 12,704评论 2 59
  • 关于Mongodb的全面总结 MongoDB的内部构造《MongoDB The Definitive Guide》...
    中v中阅读 31,914评论 2 89
  • 【学龄后】口号:温柔地坚持 孩子第一个30天目标:在洗手间刷牙,刷完牙马上洗脸 妈妈第一个30天目标:恢复与大宝的...
    zengl阅读 175评论 0 0
  • *快速排序 最优时间复杂度为nlogn,因为要完成n个嵌套调用,,但比冒泡排序要快python实现逻辑过程是这样得...
    火车火车阅读 1,849评论 0 0