Java基础知识点梳理

Java基础知识点梳理

摘要

本文主要是我在学习Java过程中写的Java基础知识点总结。Java的知识点其实非常多,并且有些知识点比较难以理解,有时候我们自以为理解了某些内容,其实可能只是停留在表面上,没有理解其底层实现原理。

我这里写了一些常见知识点,方便复习和记忆,但并不是全部内容。

1.面向对象三大特性

(1.)继承:一般类只能单继承,内部类实现多继承,接口可以多继承
(2.)封装:访问权限控制public > protected > 包 > private 内部类也是一种封装
(3.)多态:编译时多态,体现在向上转型和向下转型,通过引用类型判断调用哪个方法
(4.)运行时多态,体现在同名函数通过不同参数实现多种方法(动态分派)。

2.基本数据类型

(1.) 基本类型位数,自动装箱,常量池。
(2.) 例如byte类型是1byte也就是8位,可以表示的数字是-128到127,因为还有一个0,加起来一共是256,也就是2的八次方。
32位和64位机器的int是4个字节也就是32位,char是1个字节就是8位,float是4个字节,double是8个字节,long是8个字节。
(3.) 基本数据类型的包装类只在数字范围-128到127中用到常量池,会自动拆箱装箱,其余数字范围的包装类则会新建实例。

3.String及包装类

(1.) String类型是final类型,在堆中分配空间后内存地址不可变。
(2.) 底层是final修饰的char[]数组,数组的内存地址同样不可变。
但实际上可以通过修改char[n] = 'a’来进行修改,不会改变String实例的内存值,不过在jdk中,用户无法直接获取char[],也没有方法能操作该数组。
所以String类型的不可变实际上也是理论上的不可变。所以我们在分配String对象以后,如果将其 = “abc”,那也只是改变了引用的指向,实际上没有改变原来的对象。
(3.)StringBuffer和StringBuilder底层是可变的char[]数组,继承父类AbstractStringBuilder的各种成员和方法,实际上的操作都是由父类方法来完成的。

4.final关键字

(1.) final修饰基本数据类型保证不可变
(2.)final修饰引用保证引用不能指向别的对象,否则会报错。
(3.) final修饰类,类的实例分配空间后地址不可变,子类不能重写所有父类方法。因此在cglib动态代理中,不能为一个类的final修饰的函数做代理,因为cglib要将被代理的类设置为父类,然后再生成字节码。final修饰方法,子类不能重写该方法。

5.抽象类和接口

(1.)抽象类可以有方法实现。 抽象类可以有非final成员变量。 抽象方法要用abstract修饰。 抽象类可以有构造方法,但是只能由子类进行实例化。
(2.) 接口可以用extends加多个接口实现多继承。 接口只能有public final类型的成员变量。 接口只能有抽象方法,不能有方法体、 接口不能实例化,但是可以作为引用类型。

6.代码块和加载顺序

假设该类是第一次进行实例化。那么有如下加载顺序 静态总是比非静态优先,从早到晚的顺序是:

(1.) 静态代码块 和 静态成员变量的顺序根据代码位置前后来决定。
(2.) 代码块和成员变量的顺序也根据代码位置来决定 3. 最后才调用构造方法构造方法

7.包、内部类、外部类

(1.)Java项目一般从src目录开始有com…A.java这样的目录结构。这就是包结构。所以一般编译后的结构是跟包结构一模一样的,这样的结构保证了import时能找到正确的class引用包访问权限就是指同包下的类可见。import 一般加上全路径,并且使用.*时只包含当前目录的所有类文件,不包括子目录。
(2.) 外部类只有public和default两种修饰,要么全局可访问,要么包内可访问。
(3.) 内部类可以有全部访问权限,因为它的概念就是一个成员变量,所以访问权限设置与一般的成员变量相同。非静态内部类是外部类的一个成员变量,只跟外部类的实例有关。静态内部类是独立于外部类存在的一个类,与外部类实例无关,可以通过外部类.内部类直接获取Class类型。

8.异常

(1.)异常体系的最上层是Throwable类 子类有Error和Exception Exception的子类又有RuntimeException和其他具体的可检查异常。
(2.) Error是jvm完全无法处理的系统错误,只能终止运行。时异常指的是编译正确但运行错误的异常,如数组越界异常,一般是人为失误导致的,这种异常不用try catch,而是需要程序员自己检查。可检查异常一般是jvm处理不了的一些异常,但是又经常会发生,比如Ioexception,Sqlexception等,是外部实现带来的异常。
(3.). 多线程的异常流程是独立的,互不影响。 大型模块的子模块异常一般需要重新封装成外部异常再次抛出,否则只能看到最外层异常信息,难以进行调试。
日志框架是异常报告的最好帮手,log4j,slf4j中,在工作中必不可少。

9.泛型

(1.) Java中的泛型是伪泛型,只在编译期生效,运行期自动进行泛型擦除,将泛型替换为实际上传入的类型。泛型类用classA {}
(2.) 这样的形式表示,里面的方法和成员变量都可以用T来表示类型。泛型接口也是类似的,不过泛型类实现泛型接口时可以选择注入实际类型或者是继续使用泛型。
(3.) 泛型方法可以自带泛型比如void go();泛型可以使用?通配符进行泛化 Object可以接受任何类型,也可以使用 这种方式进行上下边界的限制。
10.Class类和Object类

(1.) Java反射的基础是Class类,该类封装所有其他类的类型信息,并且在每个类加载后在堆区生成每个类的一个Class<类名>实例,用于该类的实例化。
(2.) Java中可以通过多种方式获取Class类型,比如A.class,new A().getClass()方法以及Class.forName(“com.?.?.A”)方法。
(3.) Object是所有类的父类,有着自己的一些私有方法,以及被所有类继承的9大方法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值