在这个IT系统动辄就是上亿流量的时代,Java作为大数据时代应用最广泛的语言,诞生了一批又一批的新技术,包括HBase、Hadoop、MQ、Netty、SpringCloud等等 。
一些独角兽公司以及腾讯、阿里、百度、网易等知名大厂对Java人才的需求量连年升级,有2年工作经验的优秀程序员能轻松达到30w+的水平,但与此同时对人才的要求也越来越高。
比如,大厂的面试官经常会以如下句式来询问:
聊一聊你对JVM的原理,如何减少Full GC的情况?
针对高并发场景,如何优化,都采用了什么技术?
相比关系型数据库,NoSQL的优势在哪里,你们在什么场景下会用到?
可以看到,对于社招同学而言(特别是有2~5年工作经验的同学),不仅仅会问一些编程语言、设计模式等基础问题,还要对一些项目有深入的实战经验。
但现实却是,很多同学在技术生涯最初几年都会沉浸在业务开发中,忽视了对系统知识的梳理和技术视野的扩展。日复一日,导致很多同学就以为这就是技术的全部,同时在重复的体力劳动中也丧失了对技术细节的深入探讨。
每个程序员都追求“成就感”,而获得成就感最好的方式就是自己在技术上的突破。
技术的突破需要依赖业务场景的需求和自身刻意的规划学习,二者缺一不可,但前者是机会,往往不是自己能完全把控的,如果在自己工作中没有实践场景,最好的办法就是系统的学习与梳理,为自己制定一个不同时间段的发展道路,待机会来临时就能一展身手。
以工作前5年的规划为例,至少需要突破三个层次:
Part.1
对代码精益求精
最开始工作的时候,我们会抱怨业务需求对技术没挑战,觉得在学校学到的这么多知识却没有用武之地。
实质上这是忽略了技术开发的本质,技术开发是一个工程项目,而工程项目的落地最重要的就是细节控制,也就是代码的品质,比如:
代码是否遵循了规约?接口设计的是否随意?测试用例是否都通过?
满屏的if-else是否可以用合理的设计模式来替代?有没有遵循SOLID原则,KISS原则?
有没有考虑用更合理的数据结构和算法改变代码的复杂性,提升运行的性能?
代码出bug的概率有多大,能否降低?
这是程序员的立足之本,基本是工作1年左右要达到的。在这一阶段看书是比较好的提升方式,比如:《Java编程思想》、《effective java》等。但要注意的是,在看书的过程中一定要思考能否运用书中的经验来改善自己写的代码,运用到实处,比如看到final和static,想想自己代码中用的是否合理。
Part.2
跳出来,主动了解技术全貌
在将基础打牢之后,需要主动突破舒适区,不断的去扩大自己的技术视野,做到有广度。
这一步比较难,因为很多同学会被公司的技术和业务牵着走,比如公司当前的业务规模决定了技术上不需要分布式技术,那么很多同学就不会去思考如果规模大了之后,如何利用分布式技术解决该问题。
如何解决这个问题?除了寻找更大规模的业务外,要时刻保持时刻跳出当前层级和环境来思考的习惯。比如,你只用了关系型数据库,那么有没有想过数据一直产生,到达TB级别的时候该如何快速检索与保存呢?
此外,技术的全貌还包括各种技术之间的关系,你用了Dubbo,那么Duboo和Netty是什么关系,为什么会用到Zookeeper呢,和Spring Cloud又是什么关系?如果能在学习新技术的时候,将繁杂的技术关系理顺,会有一览众山小的感觉。
在工作的2~3年时间内达到这个水平,30w的年薪就离你不远了。
Part.3
不去造轮子,
前提是得知道轮子的内部结构
如果说,第二步是增加你的知识广度,那么造轮子就是增加你的技术深度,通过造轮子,才能真正把握技术的来龙去脉。
很多人信奉“不去造轮子”,看似性价比很高的一句话,却不知道这句话是有前提的,那就是“你得知道轮子的内部结构”,否则就是自我麻痹。接下来需要选择某一个或几个方面深入研究下去,构建自己的核心竞争力。
比如,消息队列在高并发分布式系统中一个及其重要的组件,起到削峰填谷、系统解耦的作用。我们以消费端如何快速获取数据来看思维是如何一步步深入的:
首先消费端要想及时获取数据,是否需要建立一个长连接?长连接的实现方式如何?
数据是通过push还是pull方式给到消费端,各自有什么弊端?
如果消费失败,可能是哪些原因引起?如果是因为网络原因引起,该如何解决?
这些问题都会在你自己造轮子的过程中暴露出来,从而加深你的理解和技术深度,一个有技术深度的程序员才是有灵魂的。而大厂也是愿意为有趣的灵魂买单的,这个时候看的就不仅仅是工资水平,更多的是在于晋升和发展前景的广阔性。
在Java语言上有所建树的开发者,都经历过以上3个层次。但可惜的是,囿于外界环境和自身设限,大部分的Java开发者却只停留在了第一个层次中,在日复一日的体力劳动中丧失了对技术细节的深入探讨,也丧失了晋升和薪资谈判中的筹码。
如何过渡到第二、三个层次?除了上文谈到的内容,这里我还想给你2个切身的建议:
1、扩宽自己的眼界,学着从全局看待问题,并且勇于挑战别人眼中的难题
2、持续提升你的学习能力,虽然有很多人以「在公司学不到东西」为理由离职,但你要知道:公司的目的是盈利。盈利的前提下,公司会尽力培养你,但是更多的时候能力成长还是得靠自己。学习能力弱的人,在哪里都没用。
如果你依然觉得有些茫然,不知从何下手学习 我给你推荐一份Java架构进阶路线图,里面涵盖当前互联网最火技术,你可以按照路线图自己一步一步学习也可以加入Java填坑之路:860113481跟着大牛学习~
架构筑基篇
性能优化如何理解
常用工具调优
linux基础与进阶
开源框架篇
Sprng5框架
AOP源码解析
Mybatis
IOC源码解析
Spring MVC
高性能架构篇
分布式架构思维
分布式协调和分流
高可靠数据储存
缓存和NoSQL
异步与消息中间件
分布式解决方案实战
微服务架构篇
SpringBoot
SpringCloud
Docker虚拟技术
Dubbo应用及源码解读
团队协作开发篇
Git
Maven
Sonar
Jenkins
B2C商城项目实战篇
系统设计
用户管理子系统
搜索子系统
订单子系统
商品管理子系统
支付系统
后台系统
分布式调度系统
欢迎工作一到五年的Java工程师朋友们加入Java填坑之路:860113481
群内提供免费的Java架构学习资料(里面有高可用、高并发、高性能及分布式、Jvm性能调优、Spring源码,MyBatis,Netty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多个知识点的架构资料)合理利用自己每一分每一秒的时间来学习提升自己,不要再用"没有时间“来掩饰自己思想上的懒惰!趁年轻,使劲拼,给未来的自己一个交代!