Java架构师必须掌握的 21 个 Java 核心技术!(干货)

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 写这篇文章的目的是想总结一下自己这么多年来使用java的一些心得体会,希望可以给大家一些经验,能让大家更好学习和使用Java。这次介绍的主要内容是和J2SE相关的部分,另外,会在以后再介绍些J2EE相关的、和Java中各个框架相关的内容。经过这么多年的Java开发,以及结合平时面试Java开发者的一些经验,我觉得对于J2SE方面主要就是要掌握以下的一些内容。

写这篇文章的目的是想总结一下自己这么多年来使用java的一些心得体会,希望可以给大家一些经验,能让大家更好学习和使用Java。


这次介绍的主要内容是和J2SE相关的部分,另外,会在以后再介绍些J2EE相关的、和Java中各个框架相关的内容。


经过这么多年的Java开发,以及结合平时面试Java开发者的一些经验,我觉得对于J2SE方面主要就是要掌握以下的一些内容。


1. JVM相关


对于刚刚接触Java的人来说,JVM相关的知识不一定需要理解很深,对此里面的概念有一些简单的了解即可。


不过对于一个有着3年以上Java经验的资深开发者来说,不会JVM几乎是不可接受的。


JVM作为java运行的基础,很难相信对于JVM一点都不了解的人可以把java语言吃得很透。


我在面试有超过3年Java经验的开发者的时候, JVM几乎就是一个必问的问题了。


当然JVM不是唯一决定技术能力好坏的面试问题,但是可以佐证java开发能力的高低。


在JVM这个大类中,我认为需要掌握的知识有:



2. Java的运行


这条可能出看很简单,java程序的运行谁不会呢?


不过很多时候, 我们只是单纯通过IDE去执行java程序,底层IDE又是如何执行java程序呢?很多人并不了解。


这个知识点是最最基本的java开发者需要掌握的,第一个肯定是教你如何在命令行中执行java程序,但是很多人一旦把java学完了,IDE用上了,就把这个都忘了。


为什么强调要知道这个呢,知道了java最纯粹的启动方式之后,你才能在启动出问题的时候,去分析当时启动的目录多少,执行命名如何,参数如何,是否有缺失等。


这样有利于你真正开发中去解决那些奇奇怪怪的可能和环境相关的问题。


在这里需要掌握的知识有:


  • javac 编译java文件为 class 文件
  • java 命令的使用, 带package的java类如何在命令行中启动
  • java程序涉及到的各个路径(classpath, java。library。path, java运行的主目录等)

3. 数据类型


这条没有什么好多说的,无非就是Java中的基本类型和对象类型的掌握。


可以再了解一些JDK如何自动转换方面的知识,包括装箱拆箱等,还要注意避免装箱之后的类型相等的判断。


主要知识点:


  • 基本类型: int, long, float, double, boolean 。。。
  • 对应的对象类型: Integer 等类型到基本类型的转换, 装箱和拆箱
  • Object类型: equals, hashcode
  • String 类型的特点

4. 对象和实例


在这方面,开发者需要了解class和instance的概念以及之间的差别, 这是java面向对象特性的一个基础。


主要知识点有:


Class和 Instance 的概念


Instance 创建的过程:


  • 无继承:分配内存空间, 初始化变量, 调用构造函数
  • 有继承:处理静态动作, 分配内存空间, 变量定义为初始值 , 从基类->子类, 处理定义处的初始化, 执行构造方法

需要注意的点:


  • 静态属性等从基类->子类进行初始化
  • 默认无参构造方法相关的特性

5. 访问控制


这也是java封装特性的一个基础,需要掌握的有:public protected default private 对于class, method, field 的修饰作用。


6. 流程控制


Java 流程控制的基础, 虽然有些语法不一定很常用,但是都需要了解,并且在合适的地方使用它们。


需要掌握的有:if, switch, loop, for, while 等流程控制的语法。


7. 面向对象编程的概念


这是一个java的核心概念,对于任何java开发者都需要熟练掌握。


Java中很多特性或者说知识点都是和java面向对象编程概念相关的。


在我的理解,一个好的开发者不仅仅需要了解这些特性(知识点)本身。


也更需要知道这些对象在java的面向对象编程概念中是如何体现出来的,这样更有利于开发者掌握java这门开发语言,以及其他面向对象编程的语言。


在这里只是简单罗列了一下,主要的知识点包括有:


  • 面向对象三大特性:封装,继承,多态;
  • 各自的定义概念,有哪些特性体现出来,各自的使用场景
  • 静态多分派,动态单分派的概念
  • 重载的概念和使用
  • 继承:接口多实现,基类单继承
  • 抽象,抽象类,接口
  • 多态:方法覆盖的概念和使用
  • 接口回调

8. static


静态属性在java日常开发中也是经常使用,需要了解和 static 关键字相关的用法,还有和其他关键字的配合使用, 如是否可以和 abstract, final 等关键字联合使用。


主要需要掌握的有:


  • 静态属性的定义,使用,以及类加载时如何初始化
  • 静态方法的定义和使用
  • 静态类的定义和使用
  • 静态代码块的定义和初始化时机

9. 基础知识点


这里主要罗列一些散落的,没有系统归类的一些java知识点。


在日常的开发中用到也不少。 这块内容其实还有很多,目前只是暂时归纳了这几个在这里:


包括有:


  • equals
  • hashcode
  • tring/stringbuffer
  • final
  • finally
  • finalize

10. 集合框架


这个是一个需要多加掌握的部分,做java开发,可以说没有不用到集合框架的,这很重要,这里整理的Java集合面试题及答案你必须都要清楚。


但是这里的知识点并不难,但是对于集合最好要了解内部的实现方式,因为这样有助于你在各个不同的场景选择适合的框架来解决问题,比如有1W个元素的集合,经常要进行contains判断操作,知道了集合的特性或者内部实现,就很容易做出正确的选择。


这里包括了如下内容(并发相关不包含在内):


集合框架的体系: 基础Collection ,Map


具体集合实现的内容, List ,Set ,Map 具体的实现,内部结构, 特殊的方法, 适用场景等


集合相关的工具类 Collections 等的用法


11. 异常框架


异常在java的开发中可能没有那么被重视,异常处理的最佳实战详细说明了。


一般遇到异常,直接上抛,或者随便catch一下处理之后对于程序整体运行也没有什么大的影响。不过在企业级设计开发中, 异常的设计与处理的好坏,往往就关系着这个系统整体的健壮性。


一个好的系统的异常对于开发者来说,处理应该统一,避免各处散落很多异常处理逻辑;对于系统来说,异常应该是可控的,并且是易于运维的,某些异常出现后,应该有应对的方法,知道如何运维处理,所以虽然异常框架很简单,但是对于整个企业级应用开发来说,异常处理是很重要的,处理好异常就需要了解Java中的异常体系。


这部分需要掌握的知识点不多,主要就是:


异常的体系:


Throwable


Exception


RuntimeException


Error


RuntimeException 和 一般 Exception 的区别, 具体处理方法等


12. Java IO


IO 在java中不仅仅是文件读写那么简单,也包括了 socket 网络的读写等等一切的输入输出操作。比如说 标准HTTP请求中Post的内容的读取也是一个输出的过程,等等…


对于IO,Java不仅提供了基本Input、Output相关的api,也提供了一些简化操作的Reader、Writer等api,在某些开发(涉及大量IO操作的项目)中也很重要,一般日常的开发中也会涉及(日志,临时文件的读写等)。


在这中的知识点主要有:


基本IO的体系包括有InputStream , OutputStream, Reader/Writer, 文件读取,各种流读取等,NIO 的概念, 具体使用方式和使用场景。


13. 多线程并发


多线程是Java中普遍认为比较难的一块。


多线程用好了可以有效提高cpu使用率, 提升整体系统效率, 特别是在有大量IO操作阻塞的情况下;这里整理的Java多线程面试题及答案你必须都要清楚。


但是它也是一柄双刃剑, 如果用不好,系统非但提升不大,或者没有提升,而且还会带来多线程之间的调试时等问题。


在多线程中内容有很多,只是简单说明一下Java中初步使用多线程需要掌握的知识点,以后有机会单独再详细介绍一些高级特性的使用场景。在Java技术栈公众号回复"多线程"可获取多线程系列教程。


  • 多线程的实现和启动
  • callable 与 runable 区别
  • syncrhoized ,reentrantLock 各自特点和比对
  • 线程池
  • future 异步方式获取执行结果
  • concurrent 包
  • lock

14. 网络


Java中也是提供了可以直接操作 TCP协议、UDP协议的API。


在需要强调网络性能的情况下,可以直接使用TCP/UDP 进行通讯。


在查看Tomcat等的源码中,就可以看到这些相关API的使用情况。


不过一般也比较少会直接使用TCP,会使用诸如MINA、Netty这样的框架来进行处理,因为这个方面的开发涉及不多,所以就不再详细罗列了。


15. 时间日期处理


几乎对于每个应用来说,时间日期的处理也是绕不过去的,但是JDK8 之前的时间相关API用法并不友好。


在那个时代,可以选择Joda等时间框架。到了JDK8 发布之后,全新的时间API基本融合了其他框架的优点,已经可以很好的直接使用了。


对于Java开发者来说,需要熟练地使用API来对时间和日期做相关的处理。


具体知识点不再罗列,会在以后再写个专门的文章来总结一下JDK8中时间日期API的用法。


16. XML解析/JSON解析


其实这两块内容都不是J2SE里面的内容,但是在日常开发中,和其他程序交互,和配置文件交互,越来越离不开这两种格式的解析。


不过对于一个开发者来说,能够了解一些XML/JSON具体解析的原理和方法,有助于你在各个具体的场景中更好的选择合适你的方式来使得你的程序更有效率和更加健壮。


XML: 需要了解 DOM解析和 SAX解析的基本原理和各自的适用场景


JSON: 需要了解一些常用JSON框架的用法, 如 Jackson, FastJson, Gson 等。


17. Maven使用


Maven也不是Java里面的内容,但是maven是革命性的,给java开发带来了巨大的便利,这30个Maven命令你必须熟悉。


从依赖的引入和管理,开发流程的更新和发布产出,乃至版本的更新,使用maven可以大大简化开发过程中的复杂度,从而节省大量时间。


可以说,maven已经成为java开发者的标配了。所以我把maven也作为一个java开发者对于基础必备的知识点。


18. 泛型


这是JDK5开始引入的新概念,其实是个语法糖。


在编写java代码时会有些许便利, 一般的应用或者是业务的开发,只需要简单使用,不一定会用到定义泛型这样的操作。


但是开发一些基础公共组件会使用到,可以在需要的时候再细看这个部分,一般情况下只要会简单使用即可。


19. 注解


也是jdk5 之后引入的,元注解你必须了解。


spring是个优秀的框架,最开始就以xml作为标准的配置文件。


不过到了Spring3 之后,尤其是 spring-boot 兴起之后,越来越推崇使用标注来简化xml配置文件了,对于开发者来说,可以节省不少xml配置的时间。


但是劣势是在于标注散落在各个类中,不像xml,可以对所有配置有个全局性的理解和管理,所以还没有办法说完全就取代所有的xml。


对于一般开发者,会使用标注即可,一些公共组建的开发者可能会需要了解标注的定义和实现,可以在具体需要的时候再细看。


20. RMI


RemoteMethodInvocation ,Java语言特有的远程调用接口,使用还是比较简单方便,点击这里了解RMI与RPC的区别详情。


不过需要跨语言的情况下,就需要使用 webservice 等其他方式来支持。


一般来说,程序都不需要使用RMI,不过可以在特定的情况下使用,我就在一个项目中,使用RMI来进行程序远程启动停止的控制。


21. JNI


Java Native Interface,可以允许Java中调用本地接口方法,一般用于C/C++代码的调用。


需要注意的是在java中加载so/dll文件的路径问题,本身调用接口并不复杂,但是经常在是否加载了所需的本地接口库中花费较多时间。


以上也只是简单介绍了下我对于这些java基本知识点和技术点的一些看法和介绍。


这些内容都源自于我这些年来使用java的一些总结 。这当中还有些内容不够完善的地方,会通过以后的文章再添加上。


云服务器ECS地址:阿里云·云小站

相关文章
|
6天前
|
XML Java 编译器
Java注解的底层源码剖析与技术认识
Java注解(Annotation)是Java 5引入的一种新特性,它提供了一种在代码中添加元数据(Metadata)的方式。注解本身并不是代码的一部分,它们不会直接影响代码的执行,但可以在编译、类加载和运行时被读取和处理。注解为开发者提供了一种以非侵入性的方式为代码提供额外信息的手段,这些信息可以用于生成文档、编译时检查、运行时处理等。
32 7
|
7天前
|
Kubernetes Cloud Native 微服务
探索云原生技术:容器化与微服务架构的融合之旅
本文将带领读者深入了解云原生技术的核心概念,特别是容器化和微服务架构如何相辅相成,共同构建现代软件系统。我们将通过实际代码示例,探讨如何在云平台上部署和管理微服务,以及如何使用容器编排工具来自动化这一过程。文章旨在为开发者和技术决策者提供实用的指导,帮助他们在云原生时代中更好地设计、部署和维护应用。
|
24天前
|
存储 分布式计算 关系型数据库
架构/技术框架调研
本文介绍了微服务间事务处理、调用、大数据处理、分库分表、大文本存储及数据缓存的最优解决方案。重点讨论了Seata、Dubbo、Hadoop生态系统、MyCat、ShardingSphere、对象存储服务和Redis等技术,提供了详细的原理、应用场景和优缺点分析。
|
6天前
|
运维 Cloud Native 持续交付
云原生技术深度探索:重塑现代IT架构的无形之力####
本文深入剖析了云原生技术的核心概念、关键技术组件及其对现代IT架构变革的深远影响。通过实例解析,揭示云原生如何促进企业实现敏捷开发、弹性伸缩与成本优化,为数字化转型提供强有力的技术支撑。不同于传统综述,本摘要直接聚焦于云原生技术的价值本质,旨在为读者构建一个宏观且具体的技术蓝图。 ####
|
6天前
|
JavaScript 安全 Java
java版药品不良反应智能监测系统源码,采用SpringBoot、Vue、MySQL技术开发
基于B/S架构,采用Java、SpringBoot、Vue、MySQL等技术自主研发的ADR智能监测系统,适用于三甲医院,支持二次开发。该系统能自动监测全院患者药物不良反应,通过移动端和PC端实时反馈,提升用药安全。系统涵盖规则管理、监测报告、系统管理三大模块,确保精准、高效地处理ADR事件。
|
13天前
|
运维 Kubernetes Docker
深入理解容器化技术及其在微服务架构中的应用
深入理解容器化技术及其在微服务架构中的应用
30 1
|
20天前
|
监控 Java 微服务
从零构建微服务架构:一次深度技术探索之旅####
本文作为一篇深度技术分享,引领读者踏上自底向上搭建微服务架构的征途,旨在通过实战经验剖析,揭示微服务转型背后的技术挑战与解决方案。不同于常规摘要仅概述内容,本文摘要将直接以故事化手法,简述作者从单体应用困境出发,逐步迈向微服务化的心路历程,涵盖关键决策点、技术选型考量及实践收获,激发读者对微服务架构设计与实现的浓厚兴趣。 ####
|
20天前
|
Cloud Native 持续交付 云计算
深入理解云原生技术及其在现代IT架构中的应用
在数字化浪潮的推动下,云原生技术已成为企业转型的关键。本文将通过浅显易懂的语言和生动的比喻,带领读者探索云原生的核心概念、优势以及如何在企业中实现云原生架构。我们将一起揭开云原生的神秘面纱,了解它如何助力企业快速适应市场变化,提升业务的灵活性和创新能力。
|
22天前
|
敏捷开发 缓存 中间件
.NET技术的高效开发模式,涵盖面向对象编程、良好架构设计及高效代码编写与管理三大关键要素
本文深入探讨了.NET技术的高效开发模式,涵盖面向对象编程、良好架构设计及高效代码编写与管理三大关键要素,并通过企业级应用和Web应用开发的实践案例,展示了如何在实际项目中应用这些模式,旨在为开发者提供有益的参考和指导。
21 3
|
21天前
|
Cloud Native 云计算 Docker
云原生技术的崛起:从容器化到微服务架构
云原生技术的崛起:从容器化到微服务架构