- 浏览: 1465623 次
- 性别:
- 来自: 上海
文章分类
最新评论
-
luhouxiang:
写的很不错,学习了
Extjs 模块化动态加载js实践 -
kingkongtown:
如果想改成淘宝后台那样,可以在编辑器批量上传图片呢?
kissy editor 阶段体会 -
317966578:
兄弟我最近也在整jquery和caja 开放一些接口。在git ...
caja 原理 : 前端 -
liuweihug:
Javascript引擎单线程机制及setTimeout执行原 ...
setTimeout ,xhr,event 线程问题 -
辽主临轩:
怎么能让浏览器不进入 文档模式的quirks模式,进入标准的
浏览器模式与文本模式
0.cookie 外的替代方法
1.jsf 为服务器端组件 ,有什么缺点?
2.servlet life cycle
3.为什么xml 适合web service
4.xml 元数据 怎么描述
5.javascript 什么情况下需要写在页面上。
6. set map 完全不一样
set extends collections extends Iterable
map 单独一个接口
但 hashset 用 hashmap 实现的
7.构造线程的两个方法
mythread extend Thread { run{} } new Thread( new Runnable(){ run{} });
8.ajax 如何解决 可访问性问题
<a href='服务器处理单元'> 开始 </a>
在 js 端 a.onclick={
// ajax process unit
return false;}
9.接口 和 抽象类 的 区别
接口内成员变量都是 public static final 的 (即使不显示声明, 声明 其他编译报错),方法都是 public 的 (即使不显示声明, 声明 其他编译报错 )
抽象类内和一般类没什么区别,除了不能实例化,abstract方法可以不实现,访问限制符没有任何区别。( abstract 方法不能为 private 级别 )
任何继承抽象类的类的对应方法不能弱化访问限制,只能相等或更宽泛。(所以继承一个不同包的抽象类,而该抽象类的抽象方法是包访问级别,就是死路一条 )
任何实现接口的类的对应方法都是 public 的
PS:转载一篇详细解释
abstract class
和interface是Java语言中对于抽象类定义进行支持的两种机制,正是由于这两种机制的存在,才赋予了Java强大的面向对象能力。
abstract class和interface之间在对于抽象类定义的支持方面具有很大的相似性,甚至可以相互替换,因此很多开发者在进行抽象类定义
时对于abstract class和interface的选择显得比较随意。其实,两者之间还是有很大的区别的,对于它们的选择甚至反映出对于问题领域
本质的理解、对于设计意图的理解是否正确、合理。本文将对它们之间的区别进行一番剖析,试图给开发者提供一个在二者之间进行选择的依据。
理解抽象类
abstract class和interface在Java语言中都是用来进行抽象类(本文中的抽象类并非从abstract class翻译而来,它
表示的是一个抽象体,而abstract class为Java语言中用于定义抽象类的一种方法,请读者注意区分)定义的,那么什么是抽象类,使用抽象类
能为我们带来什么好处呢?
在面向对象的概念中,我们知道所有的对象都是通过类来描绘的,但是反过来却不是这样。并不是所有的类都是用来描绘对象的,如果一个类中没有包含足够的信息
来描绘一个具体的对象,这样的类就是抽象类。抽象类往往用来表征我们在对问题领域进行分析、设计中得出的抽象概念,是对一系列看上去不同,但是本质上相同
的具体概念的抽象。比如:如果我们进行一个图形编辑软件的开发,就会发现问题领域存在着圆、三角形这样一些具体概念,它们是不同的,但是它们又都属于形状
这样一个概念,形状这个概念在问题领域是不存在的,它就是一个抽象概念。正是因为抽象的概念在问题领域没有对应的具体概念,所以用以表征抽象概念的抽象类
是不能够实例化的。
在面向对象领域,抽象类主要用来进行类型隐藏。我们可以构造出一个固定的一组行为的抽象描述,但是这组行为却能够有任意个可能的具体实现方式。这个抽象描
述就是抽象类,而这一组任意个可能的具体实现则表现为所有可能的派生类。模块可以操作一个抽象体。由于模块依赖于一个固定的抽象体,因此它可以是不允许修
改的;同时,通过从这个抽象体派生,也可扩展此模块的行为功能。熟悉OCP的读者一定知道,为了能够实现面向对象设计的一个最核心的原则
OCP(Open-Closed Principle),抽象类是其中的关键所在。
从语法定义层面看abstract class和interface
在语法层面,Java语言对于abstract class和interface给出了不同的定义方式,下面以定义一个名为Demo的抽象类为例来说明这种不同。
使用abstract class的方式定义Demo抽象类的方式如下:
abstract class Demo { abstract void method1(); abstract void method2(); … }
使用interface的方式定义Demo抽象类的方式如下:
interface Demo { void method1(); void method2(); … }
在abstract class方式中,Demo可以有自己的数据成员,也可以有非abstarct的成员方法,而在interface方式的实现
中,Demo只能够有静态的不能被修改的数据成员(也就是必须是static final的,不过在interface中一般不定义数据成员),所有的成
员方法都是abstract的。从某种意义上说,interface是一种特殊形式的abstract class。
从编程的角度来看,abstract class和interface都可以用来实现"design by contract"的思想。但是在具体的使用上面还是有一些区别的。
首先,abstract class在Java语言中表示的是一种继承关系,一个类只能使用一次继承关系。但是,一个类却可以实现多个interface。也许,这是Java语言的设计者在考虑Java对于多重继承的支持方面的一种折中考虑吧。
其次,在abstract class的定义中,我们可以赋予方法的默认行为。但是在interface的定义中,方法却不能拥有默认行为,为了绕过这个限制,必须使用委托,但是这会 增加一些复杂性,有时会造成很大的麻烦。
在抽象类中不能定义默认行为还存在另一个比较严重的问题,那就是可能会造成维护上的麻烦。因为如果后来想修改类的界面(一般通过
abstract class或者interface来表示)以适应新的情况(比如,添加新的方法或者给已用的方法中添加新的参数)时,就会非常的麻烦,
可能要花费很多的时间(对于派生类很多的情况,尤为如此)。但是如果界面是通过abstract class来实现的,那么可能就只需要修改定义在
abstract class中的默认行为就可以了。
同样,如果不能在抽象类中定义默认行为,就会导致同样的方法实现出现在该抽象类的每一个派生类中,违反了"one rule,one place"原则,
造成代码重复,同样不利于以后的维护。因此,在abstract class和interface间进行选择时要非常的小心。
从设计理念层面看abstract class和interface
上面主要从语法定义和编程的角度论述了abstract class和interface的区别,这些层面的区别是比较低层次的、非本质的。本小节将从另
一个层面:abstract class和interface所反映出的设计理念,来分析一下二者的区别。作者认为,从这个层面进行分析才能理解二者概念
的本质所在。
前面已经提到过,abstarct class在Java语言中体现了一种继承关系,要想使得继承关系合理,父类和派生类之间必须存在"is a"关系,
即父类和派生类在概念本质上应该是相同的(参考文献〔3〕中有关于"is a"关系的大篇幅深入的论述,有兴趣的读者可以参考)。对于
interface 来说则不然,并不要求interface的实现者和interface定义在概念本质上是一致的,仅仅是实现了interface定
义的契约而已。为了使论述便于理解,下面将通过一个简单的实例进行说明。
考虑这样一个例子,假设在我们的问题领域中有一个关于Door的抽象概念,该Door具有执行两个动作open和close,此时我们可以通过abstract class或者interface来定义一个表示该抽象概念的类型,定义方式分别如下所示:
使用abstract class方式定义Door:
abstract class Door { abstract void open(); abstract void close(); }
使用interface方式定义Door:
interface Door { void open(); void close(); }
其他具体的Door类型可以extends使用abstract class方式定义的Door或者implements使用interface方式定义的Door。看起来好像使用abstract class和interface没有大的区别。
如果现在要求Door还要具有报警的功能。我们该如何设计针对该例子的类结构呢(在本例中,主要是为了展示abstract class和
interface反映在设计理念上的区别,其他方面无关的问题都做了简化或者忽略)?下面将罗列出可能的解决方案,并从设计理念层面对这些不同的方案进
行分析。
解决方案一:
简单的在Door的定义中增加一个alarm方法,如下:
abstract class Door { abstract void open(); abstract void close(); abstract void alarm(); }
或者
interface Door { void open(); void close(); void alarm(); }
那么具有报警功能的AlarmDoor的定义方式如下:
class AlarmDoor extends Door { void open() { … } void close() { … } void alarm() { … } }
或者
class AlarmDoor implements Door { void open() { … } void close() { … } void alarm() { … } }
这种方法违反了面向对象设计中的一个核心原则ISP(Interface Segregation Priciple),在Door的定义中把Door概
念本身固有的行为方法和另外一个概念"报警器"的行为方法混在了一起。这样引起的一个问题是那些仅仅依赖于Door这个概念的模块会因为"报警器"这个概
念的改变(比如:修改alarm方法的参数)而改变,反之依然。
解决方案二:
既然open、close和alarm属于两个不同的概念,根据ISP原则应该把它们分别定义在代表这两个概念的抽象类中。定义方式有:这两个概念都使用
abstract class方式定义;两个概念都使用interface方式定义;一个概念使用abstract class方式定义,另一个概念使用
interface方式定义。
显然,由于Java语言不支持多重继承,所以两个概念都使用abstract class方式定义是不可行的。后面两种方式都是可行的,但是对于它们的选择却反映出对于问题领域中的概念本质的理解、对于设计意图的反映是否正确、合理。我们一一来分析、说明。
如果两个概念都使用interface方式来定义,那么就反映出两个问题:1、我们可能没有理解清楚问题领域,AlarmDoor在概念本质上到底是
Door还是报警器?2、如果我们对于问题领域的理解没有问题,比如:我们通过对于问题领域的分析发现AlarmDoor在概念本质上和Door是一致
的,那么我们在实现时就没有能够正确的揭示我们的设计意图,因为在这两个概念的定义上(均使用interface方式定义)反映不出上述含义。
如果我们对于问题领域的理解是:AlarmDoor在概念本质上是Door,同时它有具有报警的功能。我们该如何来设计、实现来明确的反映出我们的意思
呢?前面已经说过,abstract class在Java语言中表示一种继承关系,而继承关系在本质上是"is a"关系。所以对于Door这个概念,
我们应该使用abstarct class方式来定义。另外,AlarmDoor又具有报警功能,说明它又能够完成报警概念中定义的行为,所以报警概念可
以通过interface方式定义。如下所示:
abstract class Door { abstract void open(); abstract void close(); } interface Alarm { void alarm(); } class AlarmDoor extends Door implements Alarm { void open() { … } void close() { … } void alarm() { … } }
这种实现方式基本上能够明确的反映出我们对于问题领域的理解,正确的揭示我们的设计意图。其实abstract class表示的是"is a"关
系,interface表示的是"like a"关系,大家在选择时可以作为一个依据,当然这是建立在对问题领域的理解上的,比如:如果我们认为
AlarmDoor在概念本质上是报警器,同时又具有Door的功能,那么上述的定义方式就要反过来了。
from:http://jackyrong.cnblogs.com/archive/2005/11/28/252099.html
这个re文更加简练: abstract class定义的函数..可以部分实现.. interface 定义的函数 没有实现过程
abstract class的继承类要允许实现abstract class中的部分函数,或者扩展函数
interface的继承类必须完成所有interface中定义的函数 abstract class
和interface定义的类是不能被实例化的。 而实现他们的类则可以被实例化 interface是abstract class的特殊形式
interface可以多继承(既一个实现类可以作为多个接口的继承类) 而abstract
class的继承的类只能有一个超类(既:一个实现类只有一个abstract class) 如上例中:class AlarmDoor
extends Door implements Alarm 正确 class AlarmDoor extends Door extends
Alarm 错误(不支持多继承)
发表评论
-
continuation, cps
2013-09-12 16:49 2809起 随着 nodejs 的兴起,异步编程成为一种潮流 ... -
using mustache with spring mvc
2011-06-16 20:30 4721spring 基本不用介绍了,是目前最好的 IOC 容器了 ... -
备忘:使用 intellij idea 进行远程调试
2011-05-03 18:56 33607以前都是很土得打 log ,发现一篇关于 java 调试器架构 ... -
前后端编码传递
2010-10-21 00:12 2056背景: 关于编码是 BS 的开发是个大问题,包 ... -
javabean与attribute
2010-07-15 21:02 2436以前很忽视 javabean , ... -
JAVA学习路线图
2010-06-20 23:24 0最近论坛上看到好几个朋友都在问,如何学习 Java的问题, ... -
linux下定位java应用
2010-06-09 02:48 1425场景: java 应用不同于其它程序,在ps查看时程 ... -
java中的协变
2010-05-27 23:17 3359一个一直有点模糊的概念,记录一下,协变是指一个类型随着它关联的 ... -
验证码图片生成
2010-04-29 22:15 0<%@ page contentType="i ... -
利用aop重构数据访问层
2010-02-24 20:57 2102由于一直以来小项目做的多,造成了轻后端重前端的恶果,结果后端现 ... -
struts2讲义
2009-11-07 11:53 0struts2讲义 -
xml transfer for beyond compare
2009-10-22 17:33 0xml transfer for beyond compare ... -
Digester 空白保留问题
2009-10-17 16:40 1980Digester 详细介绍 : apach ... -
Jsp - pageEncoding 解析
2009-09-29 22:28 2453pageEncoding 作为 Jsp page 指令 ... -
图解JVM在内存中申请对象及垃圾回收流程
2009-09-15 20:33 0http://longdick.ite ... -
javarebel
2009-09-11 22:23 0使用JavaRebel实现即时重载javaclass更改 ... -
mac java web开发配置备忘
2009-09-05 17:02 89基本上和linux配置差不多,mac 可算兼具 linux 命 ... -
10个让我去寻找比Java更好的语言的理由
2009-08-26 13:02 0别误会我. 在我的职业生涯中我写了无数的Java代码,我当 ... -
生僻用法:finally and return
2009-08-26 12:55 1507本质上还是 reference 与 primitive val ... -
事件人工详情整理Pattern
2009-08-09 16:13 0事件人工详情整理Pattern
相关推荐
Vue.js 是一款轻量级的前端JavaScript框架,由尤雨溪开发并维护,因其易学易用、组件化开发和高性能的特点,在Web开发领域中广受欢迎。本资源包中的"Vue-dev-note-master1"可能包含了关于Vue开发的笔记、教程、示例...
在IT领域,Listener、Filter和工具是Web开发中不可或缺的部分,它们在构建高效、可扩展的应用程序中扮演着重要角色。下面将详细讲解这三个概念及其相关知识点。 首先,Listener(监听器)是Java Servlet规范中的一...
在本项目中,"ddddocr杂记,使用ddddocr、flask" 主要涉及的是一个基于Python的OCR(Optical Character Recognition,光学字符...对于Python后端开发者,尤其是对图像处理和Web开发感兴趣的,这是一个很好的实践案例。
Linux学习杂记 本文档总结了Linux学习的要点,涵盖了Linux基础知识、命令操作、文件系统、桌面环境、服务器安装等方面的知识点。 一、Linux基础知识 1. 文本模式密码不显示输入的字符,输入的密码不会出现星号或...
例如,“chrome插件开发杂记.htm”可能包含了开发者在实践中遇到的问题和解决方案,“Chrome拓展简明开发指南.htm”可能是一个简化的教程,而“我的第一个Chrome插件:天气预报应用.htm”则可能是一个完整的天气预报...
【Python3.X全栈开发】入门与进阶视频教程涵盖了Python编程语言的多个核心概念,旨在帮助初学...无论你是希望从事Web开发、数据分析、自动化脚本编写,还是机器学习和人工智能,这个全面的教程都将为你打下坚实的基础。
Oracle 9i提供了JServer组件,允许开发人员使用JavaScript与Oracle数据库进行交互。通过AJAX(异步JavaScript和XML)技术,可以实现无刷新页面更新,提高用户体验。此外,JavaScript还可以用于构建动态表单、验证...
在本篇博文中,我们将深入探讨SpringMVC框架中的向导型Controller的实现,这是SpringMVC 3.1.1版本的一个重要特性。...在开发过程中,SpringMVC的强大功能和灵活性将帮助我们构建出高效、易于维护的Web应用程序。
在“Docs:关于所有事物的杂记”这个压缩包中,我们可以期待找到一系列与软件开发、IT基础架构和数据科学相关的个人笔记。这些笔记可能是作者在长期的学习和实践中积累的知识结晶,涵盖了广泛的IT主题,旨在帮助读者...
很棒的Qt 精选列表的链接,这些链接指向在自由软件/开放源代码许可下发布的与Qt相关的很棒的库,工具和其他... 来自Cutehacks开发人员的Qt软件包管理器。 是最年轻的项目,但具有安装软件包的最佳命令行工具。 htt
这一章节主要介绍Python的基础概念及其在现实世界中的应用领域,包括但不限于科学计算、数据分析、网络爬虫、Web开发等。通过这一章节的学习,初学者可以对Python有一个大概的认识,并了解为什么学习Python。 ### ...
10. **ruby杂记1**:这部分可能包含了一些零散的Ruby编程技巧、最佳实践或者作者在开发过程中遇到的问题及其解决方案。 11. **Ruby-Rake简介**:Rake是Ruby的构建工具,类似于Java的Ant或Python的setup.py,用于...
Python3是一种广泛应用于数据分析、机器学习、Web开发和自动化任务的高级编程语言。这个入门视频教程涵盖了从基础到进阶的各个重要知识点,适合初学者系统地学习Python3。 首先,第一章“Python入门导学”将引导你...
### Velocity 用户指南详解 #### 1. 关于 Velocity Velocity 是一个开源的 Java 模板引擎,它使得 Web 页面...通过熟练掌握 Velocity 的基本概念和功能,可以显著提高工作效率,简化复杂的 Web 应用程序开发过程。
3. **集成与扩展**:可以作为独立的程序组件,用于各种应用场景,如集成到Turbine web应用程序框架中,支持真正的MVC模式开发。 **三、MudStore示例解析** 假设你负责一家在线售卖泥浆产品的商店——The Online ...
Spring.NET杂记 9.1.简介 9.2.PathMatcher 9.2.1.通用规则 9.2.2.匹配文件名 9.2.3.匹配子目录 9.2.4.大小写需要考虑,斜线可以任意 第十章. 表达式求值 10.1.简介 10.2.表达式求值 10.3.语言参考 10.3.1.文字...
标题中的“Miscellanea:不同的东西”暗示了这是一个包含多种不同主题或技术的集合,可能涵盖各种IT领域的知识碎片。...理解并掌握这些内容,对于提升Web开发能力,特别是在数据可视化的领域,是非常有价值的。
- Python的应用场景:Web开发、数据分析、人工智能等 ### 第2章 Python环境安装 - **课程目标**:教会学生如何在不同操作系统(Windows、MacOS、Linux)上安装Python环境。 - **核心知识点**: - 下载Python官方...
跳到: 关于我和引领这里的历史首先,我想指出我不是专业的开发人员-从88年代到05年代我是,但是现在我不这样做。 我是一名电气工程师和商人,负责管理数据中心及其员工,并设计UPS,HVAC和电源系统……这是我的...
【描述】"Three.js 加载3d模型(修改版)修改真机背景可透明" 暗示了这个项目是基于Three.js库的,Three.js是一个广泛使用的JavaScript库,专门用于在Web浏览器中创建和展示三维图形。在这个项目中,开发人员已经对...