这里写目录标题
1. 内部类:
- 概念:在一个类的内部,再定义一个完整的类。
- 特点:
I. 编译之后可生成独立的字节码文件。
II. 内部类可直接访问外部类的私有成员,而不破坏封装。 Outer.this.a
III. 可为外部类提供必要的内部功能组件。- 分类:
I. 成员:
1). 在类的内部定义,与实例变量、实例方法同级别的类。
2). 属于外部类的一个实例部分,创建内部类对象,必须依赖外部类对象。
3). Outer out = new Outer();
Outer.Inner in = out.new Inner(); //不具备复用性
4). 当外部类、内部类存在重名属性时,有限访问内部类属性,通过外部类类名.this.外部类实例属性
5). 成员内部类不能定义静态成员。(属于实例层面)
II. 静态:
1). 不依赖外部类对象,可直接创建或通过类名访问,也可声明静态成员。位置和成员内部类是一样的。
2). Outer.Inner.静态成员
Outer.Inner in = new Outer.Inner();
III. 局部:
1). 定义在外部类的方法中,作用范围和创建对象的范围仅限当前方法中,对外不可见。
2). 局部内部类访问外部类局部变量时,因无法保障变量的生命周期与自身相同,所以修饰为final。
3). 隐藏类的信息、限制类的使用范围。
IV. 匿名:
1). 没有类名的局部内部类
2). 必须继承一个父类或实现一个接口。
1、由于匿名内部类没有名字,所以它没有构造函数。因为没有构造函数,所以它必须完全借用父类的构造函数来实例化,换言之:匿名内部类完全把创建对象的任务交给了父类去完成。
3). 定义类、实现类、创建对象的语法合并,只能创建一个该类的对象。
4). 优:减少代码量,书写的思路流畅。
5). 劣:可读性较差。
public static Teacher getTeacher(int i) {
class AdvancedTeacher extends Teacher{ //局部内部类外部无法访问
@Override
public void teach() {
System.out.println("高级老师在上课");
}
}
Teacher currentTeacher = null;
if(i % 2 == 0) {
currentTeacher = new AdvancedTeacher();
}else {
currentTeacher = new Teacher() { //匿名内部类
@Override
public void teach() {
System.out.println("初级老师在上课");
}
};
}
return currentTeacher;
}