实验三为适配器模式,实现起来很简单,但是原理非常重要。在以下情况下可以使用适配器模式:当系统想要使用现有的类,但是现有类的接口不符合系统的需要时;当需要通过创建一个可复用的类,使得本来接口不相容并且无关的类结合在一起工作时;在设计中需要改变多个子类接口,在作用相同但名称不同的类或方法之间进行适配时。书上的这段话我觉得对何时使用适配器很重要因此摘抄下来。为了完成多个功能,但是这多个功能又不在同一个类中,使用适配器就能解决这个问题。而适配器模式又分为类适配器和对象适配器。类适配器是使适配器继承已有的类,并在适配器内部再写其他需要使用的方法;而对象适配器则是在适配器中直接调用已有类的方法。这两种适配器应如何选择应看实际情况,哪种容易实现就选哪一种适配器。尽管适配器不难,但是我觉得在以后的编程中,是一定要用到适配器模式的,个人感觉十分重要。如果在程序代码中用上适配器,可让代码简练,可读性高,而且编码十分方便。在做实验的时候,第一次我是做错了的,我是直接在适配器类里编写int型排序,这是错误的。上课听了老师的讲解后,才发现应该利用double型排序的代码来实现int型排序,类适配器和对象适配器均是如此。
SortValidator接口
//SortValidator接口被适配器实现
public interface SortValidator {
public abstract void quickSortInt(int[] a);
public abstract void quickSortDouble(double[] a);
}
类SortAdapter
//类SortAdapter,继承DoubleSort,并实现SortValidator接口
public class SortAdapter extends DoubleSort implements SortValidator {
@Override
public void quickSortInt(int[] a) {
double[] b = new double[a.length];
for (int i = 0; i < a.length; i++) {
b[i] = (double) a[i];
}
super.quickSortDouble(b);
for (int i = 0; i < a.length; i++) {
a[i] = (int) b[i];
}
}
}
整型排序的按钮监听器
private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) {
int[] a = {2,5,9,8,5,4,15,12,16};
SortAdapter adapter = new SortAdapter();
adapter.quickSortInt(a);
jTextArea1.setText("");
for(int i = 0;i<a.length;i++)
jTextArea1.append(String.valueOf(a[i]) + " ");
}
double型排序的按钮监听器
private void jButton2ActionPerformed(java.awt.event.ActionEvent evt) {
double[] a = {2.2,5.6,4.5,4.9,4.8,5.7,5.5,10.2,0.5};
SortAdapter adapter = new SortAdapter();
adapter.quickSortDouble(a);
jTextArea2.setText("");
for(int i = 0;i<a.length;i++)
jTextArea2.append(String.valueOf(a[i]) + " ");
}