类的加载概述和加载时机:
A:概述
当程序要使用某个类时,如果该类还未被加载到内存中,则系统会通过加载,连接,初始化三步来实现对这个类进行初始化
加载
就是将class文件读入内存,并为之创建一个Class对象。任何类被使用是系统都会建立一个class对象
连接
验证 是否有正确的内部结构,并和其他类协调一致
准备 负责为类的静态成员分配内存,并设置默认初始化值
解析 将类的二进制数据中的符号引用替换为直接引用
初始化
就是初始化步骤
B:加载时机
创建类的实例
访问类的静态变量,或者为静态变量赋值
调用类的静态方法
使用反射的方式来强制创建某个类或接口对应的java.lang.class对象
初始化某个类的子类
直接使用java.exe命令来运行某个主类
类加载器的概述和分类:
A:概述
负责将.class文件加载到内存中,并为之生成对应的class对象。
B:分类
Bootstap ClassLoader 根类加载器
Extension ClassLoader 扩展类加载器
System ClassLoader 系统类加载器
C:作用
Bootstap ClassLoader 根类加载器
也被称为引导类加载器,负责java核心类的加载
比如System,String。在JDK中jre的lib目录下rt.jar文件中
Extension ClassLoader 扩展类加载器
负责JRE的扩展目录中jar包的加载
在JDK中jre的lib目录下ext目录
System ClassLoader 系统类加载器
负责在JVM启动时加载来自java命令的class文件,以及classpath环境变量所指定的jar包和类路径
反射概述:
A:概述
JAVA反射机制实在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法
对于任意一个对象,都能够调用它的任意一个方法和属性
这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制
要想解剖一个类,必须先要获取到该类的字节码文件对象
而解剖使用的就是class类中的方法,所以先要获取到每一个字节码文件对应的class类型的对象
B:三种方式
a:Object类的getClass()方法,判断两个对象是否是同一个字节码文件
b:静态属性class。锁对象
c:class类中静态方法forName(),读取配置文件
class.forName()读取配置文件实例:
榨汁机榨汁
通过反射获取带参数构造方法并使用:
Constructor
通过反射获取成员变量并使用:
Field
通过反射获取方法并使用:
Method
通过反射越过泛型检查:
通过反射写一个通用的设置某个对象的某个属性为指定的值:
练习:
动态代理的概述和实现:
A:概述
代理:本来自己做的事情,请了别人来做,被请的人就是代理对象
动态代理:在程序运行过程中产生的这个对象,动态代理其实就是通过反射来生成一个代理
模板设计模式概述和使用:
A:概述
模板方法模式就是定义一个算法的骨架,而将具体的算法延迟到子类来实现
B:优点和缺点
a:优点
使用模板方法模式,在定义算法骨架的同时,可以很灵活的实现具体的算法,满足用户灵活多变的需求
b:缺点
如果算法骨架有修改的话,则需要修改抽象类
JDK5新特性(自己实现枚举类):
A:概述
是指将变量的值一一列出来,变量的值只限于列举出来的值的范围内。
B:回想单例设计模式:单例类是一个类只有一个实例
那么多例类就是一个类有多个实例,但不是无限个数的实例,而是有限个数的实例。这才能是枚举类
C:Demo
通过enum实现枚举类:
枚举的注意事项:
定义枚举类要用关键字enum
所有枚举类都是Enum的子类
枚举类的第一行上必须是枚举项,最后一个枚举项后的分号是可以省略的,但是如果枚举类有其他的东西,这个分号就不能省略。最好不要省略
枚举类可以有构造器,但必须是private的,它默认的也是private的
枚举类也可以有抽象方法,但是枚举项必须重写该方法
枚举类的常见方法:
JDK7的六个新特性:
A:二进制字面量
B:数字字面量可以出现下划线
C:switch 语句可以用字符串
D:泛型简化,菱形泛型
E:异常的多个catch合并,每个异常用或|
F:try-with-resources 语句
JDK8的新特性:
接口中可以定义有方法体的方法,如果是非静态,必须用default修饰
如果是静态的就不用