想要成为一名java高级工程师得具备一些什么技能?

分类:计算机 | Java | 综合 1294
更新:2022-03-15 18:40:45
编辑

转载地址

https://www.zhihu.com/question/423351199

1 摘录1

一名高级Java开发工程师需要具备的技能很多,初级工程师、中级工程师、高级工程师。

初级工程师

一般工作一到三年,熟练掌握Java基础知识,Java多线程并发机制,JavaWeb容器原理及垃圾回收,会使用Spring,Mybatis等框架,能够代码规范,代码清晰,逻辑有序,有良好的编程习惯。

中级工程师

工作3到6年,能使用算法和多线程技术,熟练掌握反射机制,能写出常用的几大框架,深入了解底层原理,熟悉框架,单独写项目。

高级工程师

8年以上工作经验,懂源码和底层原理,能够结合业务需求造框架,深入理解高并发,多线程,jvm,操作系统等,精通数据库,算法等。

2 摘录2

高级Java程序员需要学习的知识点:

1、Core Java,Java基础,JDK的类库,很多童鞋都会说,JDK我懂,但是懂还不足够,知其然还要知其所以然,JDK的源码写的非常好,要经常查看,对使用频繁的类,比如String,集合类(List,Map,Set)等数据结构要知道它们的实现、不同的集合类有什么区别,然后才能知道在一个具体的场合下使用哪个集合类更适合、更高效,这些内容直接看源代码就OK了。

2、多线程并发编程,现在并发几乎是写服务端程序必须的技术,那对Java中的多线程就要有足够的熟悉,包括对象锁机制、synchronized关键字,concurrent包要非常熟悉。

3、I/O,Socket编程,首先要熟悉Java中Socket编程,以及I/O包,再深入下去就是Java NIO,再深入下去是操作系统底层的Socket实现,了解Windows和Linux中是怎么实现Socket的。

4、JVM要了解,拓展眼界,了解之后眼界会更宽阔,比如Java内存模型(会对理解java锁、多线程有帮助)、字节码、JVM的模型、各种垃圾收集器以及选择、JVM的执行参数(优化JVM)等,可以去Oracle网站上查看具体版本的JVM规范。

5、设计模式,如单例、模板方法、代理、适配器等等,以及在Core Java和一些Java框架里的具体场景的实现,这个可能需要慢慢积累,先了解有哪些使用场景,见的多了,自己就自然而然会去用。

6、常用数据库(Oracle、MySQL等)、SQL语句以及一般的优化。

7、JavaWeb开发的框架,如Spring、iBatis等框架,熟知原理。

8、其它一些有名的用的比较多的开源框架和包,Netty网络框架,Apache common的N多包,Google的Guava等等,也可以经常去Github上找一些代码看看。

3 摘录3

Redis、Elasticsearch、Hbase作为Java工程师必会的技术栈,尝尝作为面试的考核点。特别是互联网大厂,不仅要求面试者了解这些考核点,还需要深入理解底层原理,所以掌握Redis、Elasticsearch、Hbase成为Java工程师的必备技能。

4 摘录4

https://zhuanlan.zhihu.com/p/83904890

对于一个高级Java开发程序员来说,需要掌握哪些技能呢?

第一个是基础

比如对集合类,并发包,IO/NIO,JVM,内存模型,泛型,异常,反射,等有深入的了解,最好是看过源码了解底层的设计。比如一般面试都会问ConcurrentHashMap,CopyOnWrite,线程池,CAS,AQS,虚拟机优化等知识点,因为这些对互联网的企业是绝对重要的。

而且一般人这关都过不了,还发牢骚说这些没什么用,为什么要面试。举一例子,在使用线程池时候,因为使用了无界队列,在远程服务异常情况下导致内存飙升,怎么去解决?你要是连线程池都不清楚,你怎么去玩?

再举一例,由于对ThreadLocal理解出错,使用它做线程安全的控制,导致没能实现真的线程安全。所以作为一个拿三万的Java程序员这点基础是要有的。

第二你需要有全面的互联网主流技术相关知识

从底层说起,你起码得深入了解mysql、redis、mongodb,nginx,tomcat,rpc,jms等方面的知识。你要问需要了解到什么程度,我可以给你说个大概。首先对于MySQL,你要知道常见的参数设置,存储引擎怎么去选择,还需要了解常见的索引引擎,知道怎么去选择。知道怎么去设计表,怎么优化sql,怎么根据执行计划去调优。

高级的你需要去做分库分表的设计和优化,一般互联网企业的数据库都是读写分离,还会垂直与水平拆分,所以这个也有经验的成分在里面。

然后redis,mongodb都是需要了解原理,需要会调整参数的,而nginx和tomcat几乎都是java互联网方面必配,其实和阿里的技术栈选择有点关系。

至于rpc相关的就多了去,必须各种网络协议,序列化技术,SAO等等,你要有一个深入的理解。现在应用比较广的rpc框架,在国内就是dubbo了,可以自行搜索。至于jms相关的起码得了解原理吧,一般情况下不是专门开发中间件系统和支撑系统的需要了解太多细节,国内企业常用的主要是activeMQ和kafka。

你能对我说的都研究的比较深入,阿里p7都不是太大的问题,当然这个还需要看你的架构能力方面的面试表现了。

第三就是编程能力,编程思想,算法能力,架构能力

首先排序和查询的基本算法得会,编程思想是必须的,问你个AOP和IOC你起码得清清楚楚,设计模式不说每种都用过,但也能了解个几种吧。

编程能力这个我觉得不好去评价,但是拿一个2000W用户根据姓名年龄排序这种题目也能信手拈来。最后就是架构能力,这种不是说要你设计个多牛逼多高并发的系统,起码让你做一个秒杀系统,防重请求的设计能快速搞定而没有坑吧。

因此在这里我也给那些技术想达到这个高度甚至想往架构师发展的Java程序员提供一份详细的进阶路线图,主要针对1-5年及以上工作经验的Java开发人员,从广度到深度架构图还比较全面的,里面的技术包涵了Java高并发、微服务、源码分析、源码分析、高性能、分布式等内容,这些也是目前互联网企业比较常用的技术,那么来详细看看。

01、底层源码分析

学习Java技术体系,设计模式,流行的框架与组件,常见的设计模式,编码必备,Spring5,做应用必不可少的最新框架,MyBatis,玩数据库必不可少的组件......

02、分布式架构

高并发,高可用,海量数据,没有分布式的架构知识肯定是玩不转的,要了解分布式中的,分布式架构原理,分布式架构策略,分布式中间件,分布式架构实战等等内容。

03、微服务架构

业务越来越复杂,服务分层,微服务架构是架构升级的必由之路。比如:微服务框架,Spring Cloud,Docker与虚拟化,微服务架构。

04、性能优化

任何脱离细节的ppt架构师都是耍流氓,向上能运筹帷幄,向下能解决一线性能问题,比如:性能指标体系,JVM调优,Web调优,DB调优等等....

05、多线程并发

从架构设计,到应用层调优,再深入了解底层原理,扎实的Java基本功才能让自己变为扫地神僧:内存模型,并发模式,线程模型,锁细节等等.....