关于开发学习文章摘要
首先,前五年,如果一个程序员大致能做到一下几点「后面还会详谈」。
具有扎实的基本功
能快速完成领导交给你的代码开发任务
能在遇到问题的时候有正确的解决思路
能对公司的新人进行一定辅导,包括但不限于技术点分享、代码评审、需求分析、表结构设计等
那么,从第五年开始,我认为可以、也应当朝更高的层次进行迈进,前一个层次如果更多是偏重个人,那么这个层次我认为更多应该偏重团队,简单罗列一下大致上应该有。
系统设计能力,或许在之前给一个功能,能从 DB 设计 --> 服务端开发 --> 前端开发一栈把事情都做好,那么之后,在领导给出具体一块大业务,比如想做一个淘宝商场的会员模块,能充分分析出整个功能并把功能拆分成一个一个的点、能对每一个点之间的交互画出交互图、能梳理清楚数据库的 ER 关系图、能把工作合理分配给同事进行开发。
带领团队能力,大致就是把控整体开发节奏,保证在约定时间点前进行交付,不出现延期的情况。
大而博不如小而美,会 10 门技术、每门技术掌握到 6 分,不如会 5 门技术、2 门技术掌握到8分,我感觉整个行业什么都会一点的人比较多,把一门技术进行深入研究的比较少,毕竟掌握也许只需要 1 星期,深耕或许需要1 个月甚至更久。在五年这个节点,我认为选择一到两个自己感兴趣的方向进行深入研究会是一个比较好的选择。
这是我自己的思考,也是我在第五年开始对自己的要求,希望这一些思考也能给大家带来一些启发。
五年节点,我理解的优秀程序员应当具备的技术素质
广告
查看详情
网上有很多所谓的 Java 程序员面试经,其实看下来的感觉就是没多大用,面试是没有套路的,每一个面试官问的东西也都不一样,如果根据那些面试问题去学习和准备,那真的是只见树木不见森林,对个人提升没有太大提高。
那么,在五年这个阶段,一个优秀的程序员应当具备怎样的技术素质呢?按照我个人的理解,主要就是基本功 + 项目。
为什么之前说针对面试题进行学习和准备作用不大,因为我认为我们关注的不应当是题,而是题背后的一个一个的方向,这也就是我认为的基本功。那从基本功的角度来说,罗列一下我能想到的,包括但不限于以下内容。
工作相关使用到的JDK类及其相关源码、机制。
设计模式,设计模式在工作中用到了哪些,具体使用场景。
并发类的相关知识,线程安全、锁机制、信号量、闭锁、栅栏、线程池等。
框架相关,Spring相关机制、Spring MVC 相关机制、MyBatis 相关机制、使用的细节点、框架实现原理等。
JVM,内存布局、垃圾识别算法、垃圾回收算法、垃圾收集器、类加载机制、内存模型、出现内存问题时定位问题的方法等。
数据库的基本数据类型、索引机制、各引擎区别、锁机制、慢 SQL 定位及优化等。
缓存机制,这里的机制指的是缓存加载、缓存击穿、缓存雪崩这些机制及其相关应对方案,用过 Redis、MemCache 的最好理解一下它们的原理或者缓存提供的一些高级功能,集群如何实现
分布式的一些知识,比如 CAP 理论、数据一致性的几种解决方案、分布式事务如何处理,分库分表怎么做、现有的相关解决方案等
NIO 的作用,epoll 模型是否知道一些,Netty 的相关机制、Netty 相比原生NIO 的优点、半包拆包、断线重连解决方案等
Web 相关,Get 与 Post 的区别、转发与重定向的区别、跨域问题如何解决、如何保证接口幂等性等
网络层相关,三次握手和四次握手、全连接队列和半连接队列、负载均衡算法等
其他中间件,MQ作用和使用场景、服务化治理框架的作用和使用场景、配置中心的作用和使用场景等
数据结构,数组、链表、栈、队列、树等优缺点,在什么场景下使用什么数据结构
Linux 相关知识,基本命令的使用,查询日志、定位问题,项目或者第三方组件的基本运维等
坦白讲,以上的这些东西全都掌握也不可能,哪怕面试官肯定也有很多不会的,但这就是基本功,能多掌握一点多掌握一点,技多不压身,至于别人如何评价你,就留给别人去评价吧,做好自己能做好的就行了。我在之前写过的文章中反复强调深度 + 广度,深度优先、广度次之,有了深度 + 广度,在开发过程中我们可以尽快完成需求,在遇到问题情况下我们可以第一时间找到应对方案。
在三年的时间点,能掌握上述的知识点我认为已经是非常非常优秀的了,但这两年的经历让我意识到的是,到了五年的时间点,如果只是具备这些硬性技能,还是不够,这两年更多的应当是在项目上进行积累,也就是前面说的项目,大致上应该有。
独立完成复杂业务,或者完成一个已有项目中的大功能点,这就需要有根据业务对功能进行分解、分析的能力。
独立排查复杂问题,在项目运行过程中,一定不可能安然无事,除开业务性的问题,CPU 100%是否能独立排查、内存溢出是否能独立排查、应用死锁或者 DB 死锁能否独立排查、API调用时间长能否独立排查,以上问题排查完毕能否及时解决。
带领团队的能力,可能这时候带领的是 1~2 个人的小团队,即使一个小团队,也能考验带团队、任务合理分配的能力。
可能上面的要求有点高,可能工作中未必有这样的机会,但是不要抱怨,机会永远留给有能力、有准备的人,我们首先想的不应该是等待别人交给你一件有挑战性的事情,你在做这件事情的情况下去提升自己,而应当是先提升自己的素质,然后让别人放心把有挑战性的事情交给你来做。
回到我之前写的,为什么16年到18年间,领导愿意给我机会去进行尝试,首先就是因为个人水平的提升。
最后的最后
我想的是,无论进入了 BAT 还是进入了 FLAG,都绝不是技术道路的终点,不是可以高枕无忧地躺在过去的功劳簿上、无忧无虑过完下辈子的资本,相反,必须更努力,才能在一群同样优秀的人中脱颖而出。
......