最近,又是跳槽换工作的黄金季节,也就是大家俗称的「金九银十」。
有的读者可能会问为什么呢?那我就来给你说道说道。
对于大公司而言,会在如下两个时间节点之前进行对员工一年的绩效考核和奖金发放。
以12月31日为财年的,1月份考核统计,2月份发奖金,3-4月份面试/跳槽。
以6月30日为财年的,7月份考核,8月份发奖金,9-10月份面试/跳槽。
因此,这两个时间段是大多数程序员跳槽的高峰期。但是,无论如何建议大家做好自己的职业规划,不要为了跳槽而跳槽,眼光要放长远一点,千万不要裸辞。。。
好了,言归正传,本文主要回答一个读者的提问。
问题:一般工作的三年的程序员应该达到什么样的水平才算合格呢?
下文的答案是我工作这些年的一点经验分享,希望对你跳槽有所帮助。
对于工作三年的 Java 程序员来说,不一定非得要你「举一反三」,你应该要达到「举一反一」的效果。
我之前就跟我的很多读者说过,大多数人干了三年还抵不上别人干一年,这也就是大多数 Java 程序员所面临的瓶颈 —— 「高不成低不就」。
我觉得要突破这个瓶颈你可以从如下三个方面来提升。
一、工具
你一定要熟练一款操作系统,一款 Java 开发工具,一款浏览器,Bug 分析工具,性能分析工具等。
对于操作系统而言,我建议你用 Mac ,因为它是类 Unix 系统,方便你熟悉 Linux 命令,因为你所开发的 Java 项目,95% 以上都是跑在 Linux 上面,这样面试的时候,也不至于面试官问你几个常见的命令而不知所云。
对于 Java 开发工具而言,我建议使用 IDEA,原因很简单,想比于其它工具而言,它会更懂你。
对于浏览器而言,毫无争议的建议你用 Chrome。
对于 bug 分析工具而言,太多了,有 Java 自带的jdb、jinfo、jps、jstack、jmap、jstat、jconsole、jvisualvm 等,也有商用 JProfiler,还有动态跟踪的btrace 等。
对于性能分析工具,我建议你掌握两款 ab 和 jmeter 足矣。
二、Java 基础
作为一名 Java 程序员,你一定要对 Java 语言掌握的非常熟悉,熟悉到常见类的用法,在什么样的环境应该用什么样的类,以及要明白为什么要这么用。
比如 Java 的数据结构,字符串、数组、List、Set、Map等。你要明白这些结构的用法,那些适合用在并发的环境,那些又不适合,如果误用了会产生什么样的后果。
并发也你必须了解的,其实并发说白了,就是 Java 用来解决内存的可见性和程序执行的可见性。即 volatile 关键字、synchronize 关键字,以及在它们基础上衍生出来的 AQS 和原子变量类,又在它们之上继续产生的 Lock、同步器、阻塞队列、Executor、并发容器,以及一些开源的调度框架 spring task、quartz。
JVM 常问,如果你经常写业务,会很少接触,但是面试官会常问,所以你需要掌握,比如它的内存模型,每个区该干什么?一个字节码类的结构是怎么样的?有哪些常见的回收器,以及那些常见的垃圾收集算法?一个类的加载过程又是怎样的?JVM做了那些编译优化?有那些语法糖?等等
最近,JDK 11 马上又要发布了,那么 JDK8 你应该要了解一下吧,它的那些新特性你用过没?
上面的这些就是所谓的基础,你可以试着反问一下自己是不是应该掌握呢?
三、熟悉一个领域
既然工作了三年,那么大大小小的项目,相信你肯定做了不少,那么你至少应该擅长一个领域。比如缓存、数据库、分布式框架、一些常见的组件。
对于缓存而言,你要理解 memchache 和 redis 中的一个,比如什么是一致性hash?redis 线上你遇到过的什么问题,你又是怎么解决的?
对于数据库而言,大多数互联网公司都是用的 MySQL,因此,你需要对它特别熟悉,面试官的一个查询需求,你能快速的转换成 SQL 语句。什么是最左原则?怎么建立索引才能提高命中率?如果出现慢查询又该怎么分析问题?每种存储引擎的数据结构又是怎么样的?什么情况下会出现死锁?事务又是怎么回事?等等
对于分布式框架而言,有的用 dubbo,有的用 spring cloud,无论你用什么,它们的最核心的东西基本一样,都有注册中心、服务端、消费端以及监控中心。因此,你要把它们理解清楚。
一些常见的组件,比如 Mybatis 、Guava、Common包等等,你得知道它的常见用法,以及这些用法的背后实现原理。
总结一下,对于三年的 Java 程序员而言,一和二必须掌握,三选择一个感兴趣的方向深入研究。
无论你工作多少年,我希望你永远记住『我是一名计算机工程师,不是打字员』。。。