谈一谈个人对于java内部类的理解
谈一谈个人对于java内部类的理解
内部类分为非静态内部类和静态内部类,在这里我就他们在java中的应用谈一谈个人的理解
非静态内部类
非静态内部类也就是普通的内部类,参考ArrayList的源码,其中就用到了非静态内部类。 (下面是数据结构与算法一书中的代码)
public class MyArrayList<AnyType> implements Iterable<AnyType> { @Override public Iterator<AnyType> iterator() { ArrayListIterator iterator = new ArrayListIterator(); return iterator; } //定义一个内部类,用来返回一个关联当前对象的迭代器对象 private class ArrayListIterator implements Iterator<AnyType> { private int current = 0; private int a = 0; @Override public boolean hasNext() { return current < size(); } @Override public AnyType next() { if (!hasNext()) { throw new NoSuchElementException(); } return theItems[current++]; } } }
可以看到,他在ArrayList中封装了一个实现迭代器接口的类,然后在ArrayList中提供一个返回这个类实例的方法。
那么问题来了,在这里,内部类的作用到底是什么?
其实,书里对使用此处使用内部类做出了详细的解释,首先这样做,试着将迭代器作为一个顶级类,那么两个顶级类无法访问各自的变量及方法,显然不可行。接着,还是将迭代器作为一个顶级类,但是在这个类中存储一个ArrayList的引用,问题基本可以得到解决,只要将ArrayList的成员变量设置成公共的即可,但是这样会出现主次不分的问题,我想要遍历一个ArrayList的实例,竟然需要新建一个ArrayList的迭代器,迭代器中包含了一个List的引用,搞得好像我需要的是一个迭代器对象,list只是附带的一样。所以,这里使用内部类显然就很好的解决了这个问题。
静态内部类
LinkedList的源码中则使用到了静态内部类,这个则很好理解,静态内部类其实就是一个顶级类,只是影藏在了另一个顶级类里,这样,别的地方就不能新建这个类的实例,因为没有必要。当然,静态内部类完全可以弄成一个public class,但是没有必要。
上一篇:
IDEA上Java项目控制台中文乱码