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

本文涉及的产品
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
简介: 写这篇文章的目的是想总结一下自己这么多年来使用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地址:阿里云·云小站

相关文章
|
11天前
|
存储 缓存 API
探索后端技术:构建高效、可扩展的系统架构
在当今数字化时代,后端技术是构建任何成功应用程序的关键。它不仅涉及数据存储和处理,还包括确保系统的高效性、可靠性和可扩展性。本文将深入探讨后端开发的核心概念,包括数据库设计、服务器端编程、API 开发以及云服务等。我们将从基础开始,逐步深入到更高级的主题,如微服务架构和容器化技术。通过实际案例分析,本文旨在为读者提供一个全面的后端开发指南,帮助大家构建出既高效又具有高度可扩展性的系统架构。
|
16天前
|
Java
死磕-java并发编程技术(二)
死磕-java并发编程技术(二)
|
16天前
|
存储 Java 调度
死磕-java并发编程技术(一)
死磕-java并发编程技术(一)
|
16天前
|
存储 监控 容灾
微信技术总监谈架构:微信之道——大道至简(演讲全文)
在技术架构上,微信是如何做到的?日前,在腾讯大讲堂在中山大学校园宣讲活动上,腾讯广研助理总经理、微信技术总监周颢在两小时的演讲中揭开了微信背后的秘密。 周颢把微信的成功归结于腾讯式的“三位一体”策略:即产品精准、项目敏捷、技术支撑。微信的成功是在三个方面的结合比较好,能够超出绝大多数同行或对手,使得微信走到比较前的位置。所谓产品精准,通俗的讲就是在恰当的时机做了恰当的事,推出了重量级功能,在合适的时间以最符合大家需求的方式推出去。他认为在整个微信的成功中,产品精准占了很大一部分权重。
42 1
微信技术总监谈架构:微信之道——大道至简(演讲全文)
|
2天前
|
Kubernetes Cloud Native 云计算
云原生时代的技术演进:Kubernetes与微服务架构的完美融合
随着云计算技术的飞速发展,云原生概念逐渐深入人心。本文将深入探讨云原生技术的核心——Kubernetes,以及它如何与微服务架构相结合,共同推动现代软件架构的创新与发展。文章不仅剖析了Kubernetes的基本工作原理,还通过实际案例展示了其在微服务部署和管理中的应用,为读者提供了一条清晰的云原生技术应用路径。
10 2
|
12天前
|
传感器 监控 数据可视化
【Java】智慧工地解决方案源码和所需关键技术
智慧工地解决方案是一种新的工程全生命周期管理理念。它通过使用各种传感器、数传终端等物联网手段获取工程施工过程信息,并上传到云平台,以保障数据安全。
44 7
|
17天前
|
监控 Android开发 iOS开发
深入探索安卓与iOS的系统架构差异:理解两大移动平台的技术根基在移动技术日新月异的今天,安卓和iOS作为市场上最为流行的两个操作系统,各自拥有独特的技术特性和庞大的用户基础。本文将深入探讨这两个平台的系统架构差异,揭示它们如何支撑起各自的生态系统,并影响着全球数亿用户的使用体验。
本文通过对比分析安卓和iOS的系统架构,揭示了这两个平台在设计理念、安全性、用户体验和技术生态上的根本区别。不同于常规的技术综述,本文以深入浅出的方式,带领读者理解这些差异是如何影响应用开发、用户选择和市场趋势的。通过梳理历史脉络和未来展望,本文旨在为开发者、用户以及行业分析师提供有价值的见解,帮助大家更好地把握移动技术发展的脉络。
|
18天前
|
缓存 负载均衡 Dubbo
Dubbo技术深度解析及其在Java中的实战应用
Dubbo是一款由阿里巴巴开源的高性能、轻量级的Java分布式服务框架,它致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。
43 6
|
14天前
|
Kubernetes Cloud Native 安全
云原生技术:构建高效、灵活的现代应用架构
本文深入探讨了云原生技术的核心概念、主要特点及其在现代应用开发中的重要性。通过分析云原生技术的实际应用案例,揭示了其如何帮助企业实现应用的快速迭代、弹性扩展和高可用性。同时,文章还讨论了采用云原生技术时面临的挑战及相应的解决策略,为读者提供了一套完整的云原生技术实践指南。
|
20天前
|
Kubernetes Cloud Native Serverless
探索云原生技术:从基础架构到应用实践
本文深入探讨了云原生技术的各个方面,包括其定义、核心原则、关键技术组件以及在现代企业中的应用。通过分析云原生如何推动数字化转型和提高业务敏捷性,文章旨在为读者提供对这一领域的全面了解和实际应用的指导。
49 7