首页 > 代码库 > 缺省适配模式
缺省适配模式
如果一个类只希望实现接口中的部分方法,这时就可以考虑使用缺省适配模式。新建一个抽象类实现接口,空实现接口中所有的方法,新的类继承该抽象类,覆盖希望实现的方法即可。
以AWT中的常用的监听器为例,希望给Frame加上一个WindowListener,frame.addWindowListener()的参数是new WindowListener(),也就是可以像下面这样写代码:
frame.addWindowListener(new WindowListener(){ @Override public void windowActivated(WindowEvent e) { // TODO Auto-generated method stub } @Override public void windowClosed(WindowEvent e) { // TODO Auto-generated method stub } @Override public void windowClosing(WindowEvent e) { // TODO Auto-generated method stub } @Override public void windowDeactivated(WindowEvent e) { // TODO Auto-generated method stub } @Override public void windowDeiconified(WindowEvent e) { // TODO Auto-generated method stub } @Override public void windowIconified(WindowEvent e) { // TODO Auto-generated method stub } @Override public void windowOpened(WindowEvent e) { // TODO Auto-generated method stub } });
如果只是想重写windowClosing方法,上面的写法会显得很冗余,而且别人都知道再什么。
给Frame加上一个WindowListener,正确的方法如下:
frame.addWindowListener( new WindowAdapter() { public void windowClosing(WindowEvent e) { System.exit(0); } });
可以看WindowAdapter的源码,所有的实现都是空实现:
public abstract class WindowAdapter implements WindowListener, WindowStateListener, WindowFocusListener{ public void windowOpened(WindowEvent e) {} public void windowClosing(WindowEvent e) {} public void windowClosed(WindowEvent e) {} public void windowIconified(WindowEvent e) {} public void windowDeiconified(WindowEvent e) {} public void windowActivated(WindowEvent e) {} public void windowDeactivated(WindowEvent e) {} public void windowStateChanged(WindowEvent e) {} public void windowGainedFocus(WindowEvent e) {} public void windowLostFocus(WindowEvent e) {}}
上面就是缺省适配模式的一个很好的例子。
AWT中有很多使用缺省适配模式的实例,如下所示:
鲁智深是和尚,但是却不吃斋,念经,打坐,撞钟。如果是直接继承自和尚这个接口,那鲁智深就不是和尚了。可以让抽象类天星继承和尚接口,鲁智深作为天星的子类即可。
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。