单例设计模式:
就是采取一定## 标题的方法保证在整个的软件系统中,对某个类只能存在一个对象实例

区分饿汉式和懒汉式:
饿汉式:
坏处:对象的加载时间过长
好处:饿汉式是线程安全的
懒汉式:
好处:延迟对象的创建

单例模式的优点:
由于单例模式只生成一个实例,减少了系统性能开销

应用场景:
java-day5基础

代码块:用来初始化类、对象
代码块如果有修饰的话,只能用static

静态代码块:
随着类的加载而执行,而且只执行一次
如果一个类中定义了多个静态代码块,则按照声明的先后顺序执行
静态代码块的执行要优于非静态代码块的执行
静态代码块内只能调用静态的属性、静态的方法,不能调用非静态的结构
作用:初始化类的信息
非静态代码块:
随着对象的创建而执行,每创建一个对象就执行一次非静态代码块
如果一个类中定义了多个非静态代码块,则按照声明的先后顺序执行
非静态代码块可以调用静态和非静态的属性和方法
作用:可以在创建对象时,对对象的属性等进行初始化

final关键字:

final用来修饰一个类:此类不能被其他类所继承(没有子类)比如String System StringBuffer

final用来修饰方法:表明此方法不可以被重写 比如Object类的getclass()

final用来修饰变量:此时变量就称为是一个常量
final用来修饰局部变量:
尤其是使用final修饰形参时,表明此形参是一个常量,当我们调用此方法时,给常量形参赋一个实参,一旦赋值以后,就只能在方法体内使用此形参,但不能进行重新赋值

static final 用来修饰属性:全局常量

抽象类:abstract

abstract可以用来修饰的结构:类、方法

abstract修饰类:抽象类
此类不能实例化
抽象类中一定有构造器,便于子类实例化时调用

abstract修饰方法:抽象方法
抽象方法只有方法的声明,没有方法体
包含抽象方法的类,一定是一个抽象类,反之,抽象类中可以没有抽象方法的
若子类重写了父类中的所有抽象方法后,此子类方可实例化
若子类没有重写父类中的所有抽象方法,则此子类也是一个抽象类,需要使用abstract修饰

abstract不能用来修饰私有方法、静态方法、final的方法、final的类

创建抽象类的匿名子类对象

method()

接口:
接口使用interface来定义
接口的主要用途就是被实现类实现
Java中,接口和类是并列的两个结构

如何定义接口,定义接口中的成员:
JDK7及以前,只能定义全局变量和抽象方法:

接口中不能定义构造器,意味着接口不可以实例化

Java开发中,接口通过让类去实现(implement)的方式使用,如果实现类覆盖了接口中所有的抽象方法,则此实现类就可以实例化
如果实现类没有覆盖接口中所有的抽象方法,则此实现类仍为一个抽象类

Java类可以实现多个接口 —>弥补了Java单继承性
class AA extends BB implements CC,DD,EE

接口与接口之间可以继承,而且可以多继承

JDK8,除了定义全局变量和抽象方法以外,还可以定义静态方法、默认方法

静态方法:使用static关键字修饰,可以通过接口直接调用静态方法,并实现其方法体

接口中定义的静态方法,只能通过接口调用
通过实现类的对象,可以调用接口中的默认方法
如果实现类重写了接口中的默认方法,调用时,仍然调用的是重写以后的方法
如果子类(或实现类)继承的父类和实现的接口中声明了同名同参数的方法,那么子类在没有重写此方法的情况下,默认调用的是父类中的同名同参数的方法
如果实现类实现了多个接口,而这多个接口中定义了同名同参数的默认方法,那么在实现类没有重写此方法的情况下,报错 -->接口冲突,这就需要我们必须在实现类中重写此方法

如何在子类(或实现类)的方法中调用父类、接口中被重写的方法?
compareA.super.method()//调用接口中的默认方法

内部类:在JAVA中,允许一个类的定义位于另一个类的内部,前者称为内部类,后者称为外部类

成员内部类(静态、非静态的):
可以调用外部类的结构
可以被static修饰
可以被4种不同的权限修饰

局部内部类(方法内、代码块内、构造器内)

相关文章: