摘要:与字段和方法类似,Java答应类是其它类的成员。在这里,我们将嵌套类分为4种--嵌套顶级类(nested top-level classes),成员内部类(instance inner classes),本地内部类(local inner classes)和匿名内部类(anonymous inner classes)。
在教授Java时,我经常发现学生尝试在方法中声明其它的方法。不过,与Pascal语言不同--Pascal答应嵌套声明过程procedures(与方法类似),而Java是不答应这样做的。对于以下的代码,尝试在outerMethod()中声明innerMethod()方法,编译时将会通不过。
void outerMethod ()
{
void innerMethod ()
{
}
}
不过,由Java语言规范1.1开始,Java就支持类嵌套;Java编译器答应一个类出现在另一个类中。以下的代码段就展示了如何在outerClass类中嵌套innerClass类。
class outerClass
{
class innerClass
{
}
}
为什么Java支持类嵌套,还有Java支持哪些类嵌套?以下的部分将会回答这些问题,当你读完这篇文章,你就会学习到类嵌套的相关知识,并且运用它来写出强大的Java程序。首先我们先来看一下为什么Java支持类嵌套。
注重:在发布JDK1.1后,Sun发布了内部类规范的文档。该文档谈到嵌套顶级类和内部类的运用。在读完这篇文章后,我强烈建议你浏览这些文档。
为什么Java支持类嵌套?
Java并非一定要支持类嵌套。实际上,假如你看过内部类规范文档,你将会发现类嵌套的应用在哪里。不过,Java支持类嵌套至少有两个好处:
.令源代码更加清楚
.减少命名的冲突
通过类嵌套可以令源代码变得更为清楚,因为你声明了一个包含有一些对象的类,它必须可以治理和答应类中的方法来直接访问对象的字段,以及调用对象的方法--即使是外部类中的私有字段和方法。要理解这个好处,可用以下的一个例子说明,在这个程序中要循环遍历一个Employee对象中的Job对象:
Listing 1. JobIterator1.java
// JobIterator1.java
class Job
{
private String joBTitle;
Job (String jobTitle)
{
this.jobTitle = jobTitle;
}
public String toString ()
{
return jobTitle;
}
}
class Employee
{
private String name;
private Job [] jobs;
private int jobIndex = 0;
Employee (String name, Job [] jobs)
{
this.name = name;
this.jobs = jobs;
}
String getName ()
{
return name;
}
boolean hasMoreJobs ()
{
return jobIndex < jobs.length;
}
Job nextJob ()
{
return !hasMoreJobs () ? null : jobs [jobIndex++];
}
}
class JobIterator1
{
public static void main (String [] args)
{
Job [] jobs = { new Job ("Janitor"), new Job ("Delivery Person") };
Employee e = new Employee ("John Doe", jobs);
System.out.println (e.getName () + " works the following jobs:\n");
while (e.hasMoreJobs ())
System.out.println (e.nextJob ());
}
}
运行后, JobIterator1产生如下的输出:
John Doe works the following jobs:
Janitor
Delivery Person
JobIterator1包含有Job, Employee和JobIterator1类。Job封装了一个job的title,而Employee封装了一个员工的名字以及该员工所做工作的一个数组。JobIterator1包含有一个main()的方法用来创建Job和Employee对象,并且打印出该员工的名字和工作。
Employee类中包含有方法hasMoreJobs()和nextJob()。这两个方法构成了一个循环。当一个Employee对象初始化时,在私有jobs数组中的一个内部索引被设置为0。假如该索引的值比jobs数组的长度少,hasMoreJobs()方法返回一个布尔值true。nextJob()使用该索引值由数组中返回一个Job对象--并且增加该索引的值,以便下一次调用nextJob()时返回下一个job对象的一个引用。