上一节我们为了自定义排序创建了一个Compare的类文件 如果这时又有新需求需要按倒序排列或者改变排序方式
那么我们还需要在创建一个新的类文件么?
当然不是 这时就需要用到内部类
什么是内部类?
就是在类的内部在写一个类
以上节课MyCompare类为例 它作为母类
这时我们在MyCompare内部在写一个类叫DESCCompare
让之前的MyCompare不继承接口而是内部类继承接口
代码如下
为了模拟上面的需求
我们还需要有个升序类
这时Compare里面代码变成如下
接下来在MyIndex中如何使用内部类
代码如下
首先先实例化母类Compare类,在母类基础上实例化内部类 注意写法
MyCompare myCompare = new MyCompare();
MyCompare.DESCCompare descCompare = myCompare.new DESCCompare();
Arrays.sort(users,descCompare);
运行结果如下
接下来继续学习一个内部类的返回方式
如果还是觉得以上写法很别扭 那我们还可以写一个方法
假设我们没有写上面的Desc 和 ASCCompare方法
MyCompare中代码如下
MyIndex中如何引用
运行结果
我们在做android开发时总能看见直接new 一个接口
在做项目时如果这个排序是有各种需求的排序 需要写很多函数 我们需要单独创建一个class 文件
如果只在某个地方使用到这个排序 我们就没有必要创建一个单独的类文件了
可以直接在代码引用处直接写。这种情况有两种写法
1.假设我们在MyCompare类里面写了DESCCompare方法
只是继承了Comparator接口 没有具体实现compare的方法 返回0
代码如下
这只是简单的继承了接口 并实现了compare的方法 但是具体业务没有 这时我们可以在需要做比较的代码处直接覆盖这个方法
例如可以在MyIndex里面写入如下
运行结果如下
2.常用的写法是
我们上面创建了一个getCompare方法 直接返回一个接口 我们可以在MyIndex里面直接new Comparator() 这里的new Comparator()并不是实现接口的实例化的 接口是不能实例化的 必须有一个内部类 这个内部类是一个匿名的内部类 在这里直接覆盖原有的方法就可以了
这时我们可以直接在MyIndex里写入如下
运行结果