内部类,顾名思义,即定义在某个类内部的类,称包含该内部类的类为外部类。

从定义的位置来说,分为成员内部类和局部内部类;从类的特征来说,分为匿名内部类和静态内部类。

今天先简要介绍一下前三种内部类的定义及简单使用。

如需转载请注明出处,谢谢:

http://www.cnblogs.com/chanchan/p/8235169.html

1.成员内部类

成员内部类可看成外部类的一个成员,定义的位置与外部类的其他成员一样,只不过它是个类而已。

示例:

类Person中定义了一个成员内部类InnerClass,具体如下:

    private String hobby;
//笔记19:内部类--成员内部类
class InnerClass {
String name; void printInC() {
System.out.println("inner class");
} void printPriVar() {
System.out.println("hobby:" + hobby);
}
}
// public static void main(String[] args) { Person per = new Person(); //笔记19:内部类--成员内部类
Person.InnerClass inC = per.new InnerClass();
inC.printInC();
inC.printPriVar();
}

输出结果为:

inner class
hobby:null

分析:

(1).成员内部类可以访问外部类的private成员,当然也可以访问其他权限的成员;

也可以由访问权限修饰符来修饰。

(2).Person.InnerClass inC = per.new InnerClass();

该行定义了一个内部类的对象inC,可推知:

1>.成员内部类的类型为 外部类名.内部类名

2>.创建成员内部类对象时,要先创建一个外部类对象,再由该外部类对象使用.new来创建内部类对象;

即,成员内部类是依附于外部类的,必须由一个外部类的实例来完成对内部类对象的创建;

从这里也能理解为什么可以把成员内部类看成外部类的一个成员:一个类的非静态成员必须等创建类的实例后才会分配空间,成员内部类也类似。

2.局部内部类

局部内部类是定义在方法体与作用域内的内部类,可与局部变量类比。

示例:

类Person的成员方法localInClass中定义了一个内部类LoInnerClass,具体如下:

    //笔记19:内部类--局部内部类
public void localInClass() {
class LoInnerClass {
void printLI() {
System.out.println("local inner class");
}
}
LoInnerClass lInC = new LoInnerClass();
lInC.printLI();
}
// public static void main(String[] args) { Person per = new Person(); //笔记19:内部类--局部内部类
per.localInClass();
}

输出结果为:

local inner class

分析:

(1).局部内部类的作用域为定义它的方法体内,其他地方不可见,同局部变量。

(2).局部内部类不可以由访问权限修饰符修饰;既然其作用域只在方法体内,由访问权限修饰符修饰也没什么意义。

(3).局部内部类对象的创建不依赖于外部类,同一般类。

前面两种内部类是从定义位置来划分的,成员内部类可看成类的成员,局部内部类可看成局部变量。这两种类都有名有姓,与一般类还比较相似,只是定义位置比较特殊。下面要说的匿名内部类就更特殊,它连名字都没有,来看看具体怎么操作吧。

3.匿名内部类

匿名内部类属于局部内部类,可以作为返回值或参数,直接看示例比较直观。

示例中的AnoInnerClass是一个接口,代码如下:

package human;

public interface AnoInnerClass {
void printAnoI();
}

示例1:作为返回值

     //笔记19:内部类--匿名内部类--作为返回值
public AnoInnerClass anonymousClass() {
return new AnoInnerClass () {
public void printAnoI() {
System.out.println("anonymous inner class:return value");
}
};
} public static void main(String[] args) { Person per = new Person(); //笔记19:内部类--匿名内部类--作为返回值
AnoInnerClass anoInC = per.anonymousClass();
anoInC.printAnoI();
}

输出结果为:

anonymous inner class:return value

分析:

(1).先来看12和15行,12行创建一个Person类的对象per,15行定义AnoInnerClass类型的对象引用anoInC,并指向了per调用anonymousClass后的返回值;

成员方法anonymousClass的返回值是AnoInnerClass类型,由于AnoInnerClass类型是接口,是无法实例化的,所以返回的值必须是某个实现了该接口的类的实例,这里,这个实现了接口AnoInnerClass的类就是匿名内部类,参见3-7行;

该匿名内部类的具体内容就跟在new AnoInnerClass()后面,以{}括起来;

(2).这里还涉及到向上转型的问题

由于匿名内部类没有类名,所以第2行返回值的类型也是写得内部类的父类接口AnoInnerClass,实际返回的是匿名内部类的实例,把该实例赋给了父类的对象引用。

示例2:作为参数

     //笔记19:内部类--匿名内部类--作为参数--重载
public void anonymousClass( AnoInnerClass anoInC ){
anoInC.printAnoI();
}
// public static void main(String[] args) { Person per = new Person(); //笔记19:内部类--匿名内部类--作为参数--重载
per.anonymousClass(new AnoInnerClass() {
public void printAnoI() {
System.out.println("anonymous inner class:argument");
}
});
}

输出结果为:

anonymous inner class:argument

分析:

(1).与示例1不同的是,匿名内部类作为参数时,是在实际调用时实现的,也就是说匿名内部类是实参。

(2).其他地方与示例1大同小异。

从示例1和示例2也可以看出来,匿名内部类是属于局部内部类的。

匿名内部类没有名字,它必须要继承一个父类或实现一个接口,且只能继承或实现一个父类或接口;否则作为返回值时,返回值类型就不知道怎么表示了,作为参数时,参数类型也没法表示了。

PS:

这段时间确实有点事情,但主要是懒癌发作,拖了1个月才找回状态,实在惭愧!!!

最新文章

  1. WPF ListView展示层叠信息
  2. WORD2007多级列表
  3. 7 款令人赞叹的 HTML5 动画应用
  4. Spring+Ibatis集成开发实例
  5. Android App资源的查找过程分析
  6. DateTime格式大全
  7. 让libvirt支持win7运行2核以上
  8. PHP学习笔记十九【析构函数】
  9. 用c++语言编写函数 int index(char *s,char * t),返回字符串t在字符串s中出现的最左边的位置,如果s中没有与t匹配的子串,则返回-1。类似于索引的功能。
  10. NYOJ--541--最强DE 战斗力(递推)
  11. hadoop2 YARN/Mv2中 ApplicationMaster相关问题及介绍
  12. Java I/O---添加属性和有用的接口—FilterlnputStream&FilterOutputStream
  13. php+redis 学习 二 悲观锁
  14. matlab 图像平移操作
  15. C# 将当前应用程序写入到注册表开机启动项中
  16. 2018年2月19日我的java学习
  17. HashMap和Hashtable的区别 2
  18. C#实现根据地图上的两点坐标,计算直线距离
  19. OpenStack平台虚拟机实例在线迁移失败问题
  20. cocos源码分析--用Sprite加载自定义着色器

热门文章

  1. Android 7.1 屏幕旋转流程分析
  2. ubuntu14.04 升级mysql到5.7版本
  3. 百度编辑器的内容改变事件监听bug
  4. json解析—Gson以及GsonFormat插件的运用
  5. Mac ssh 连接报错 Permission denied (publickey)
  6. spring boot自定义starter
  7. git学习笔记5-撤销操作
  8. Python 集体智慧编程PDF
  9. [array] leetcode - 42. Trapping Rain Water - Hard
  10. 关于llvm kaleidoscope: 记一次Debug血泪之路