四年努力,梦归阿里,和大家聊聊成长感悟 (2)

系统设计能力,或许在之前给一个功能,能从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相关知识,基本命令的使用,排查日志、定位问题,项目或者第三方组件的基本运维等

坦白讲,以上的这些东西全都掌握也不可能,哪怕面试官肯定也有很多不会的,但这就是基本功,能多掌握一点多掌握一点,技多不压身,至于别人如何评价你,就留给别人去评价吧,做好自己能做好的就行了。我在之前写过的文章中反复强调深度+广度,深度优先、广度次之,有了深度+广度,在开发过程中我们可以尽快完成需求,在遇到问题情况下我们可以第一时间找到应对方案。

在三年的时间点,能掌握上述的知识点我认为已经是非常非常优秀的了,但这两年的经历让我意识到的是,到了五年的时间点,如果只是具备这些硬性技能,还是不够,这两年更多的应当是在项目上进行积累,也就是前面说的项目,大致上应该有:

独立完成复杂业务,或者完成一个已有项目中的大功能点,这就需要有根据业务对功能进行分解、分析的能力

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wppwpy.html