面向对象设计原则
《面向对象程序设计》课程设计
《面向对象程序设计》课程设计在当今数字化的时代,计算机程序设计的重要性日益凸显。
而面向对象程序设计作为一种重要的编程范式,在软件开发中发挥着关键作用。
本次课程设计旨在深入探究面向对象程序设计的原理、方法和应用,培养学生的编程思维和实践能力。
一、课程目标1、掌握面向对象的基本概念,如类、对象、封装、继承和多态等。
2、学会使用面向对象的方法进行问题分析和程序设计。
3、能够运用常见的编程语言(如 Java、C++等)实现面向对象的程序。
4、培养团队合作精神和解决实际问题的能力。
二、课程内容1、面向对象的基本概念类与对象的定义和关系封装的实现和意义继承的概念和分类(单继承、多继承)多态的表现形式(重载、覆盖)2、面向对象的设计原则单一职责原则开放封闭原则里氏替换原则依赖倒置原则接口隔离原则迪米特法则3、常用的设计模式创建型模式(工厂方法模式、抽象工厂模式、单例模式等)结构型模式(适配器模式、桥接模式、装饰器模式等)行为型模式(策略模式、责任链模式、观察者模式等)4、编程语言的实践选择一种主流的编程语言(如 Java 或 C++),进行实际的编程练习。
完成从简单的控制台应用程序到复杂的图形用户界面应用程序的开发。
三、课程实施1、理论教学通过课堂讲解、案例分析和讨论,让学生理解面向对象程序设计的基本概念和原理。
2、实践教学安排实验课程,让学生在实际操作中掌握编程语言的使用和面向对象程序的开发。
布置课程设计项目,要求学生以小组形式完成一个具有一定规模和复杂度的应用程序。
3、教学资源提供相关的教材、参考书籍和在线资源,方便学生自主学习。
利用在线教学平台,发布教学资料、作业和答疑。
四、课程考核1、平时成绩包括考勤、课堂表现、作业完成情况等。
2、实验成绩根据实验报告和实验项目的完成情况进行评定。
3、课程设计成绩从项目的需求分析、设计方案、代码实现、测试结果和团队协作等方面进行综合评价。
五、课程设计项目示例以“学生管理系统”为例,介绍面向对象程序设计的应用。
请简述面向对象设计的启发规则
请简述面向对象设计的启发规则在设计中,我们往往会根据自己已有的经验进行面向对象程序的编写。
但是实际上我们不知道为什么要这样做?我们可以怎样更好地改进面向对象设计呢?这个问题值得我们深入思考,也是我们本节课要解决的内容。
在开始之前,先给大家简单介绍一下面向对象程序设计的基本概念和几条设计规则。
1、主体是能被用户直接使用的工具,它对系统资源有使用权。
2、主体应该提供完成特定功能的信息,而不是说明完成某些特定功能所需要的过程和逻辑。
3、主体应该是对现实世界的抽象,而不是对人类经验的简单总结。
4、从属关系应该明确,如果两个主体间没有从属关系,那么从属关系就失去了意义。
5、复杂性应该控制在一定范围内。
6、如果存在可由子类扩充的方法,它也应该可以被子类继承。
7、通常情况下,应该为不同类型的方法分别提供相应的接口,方便它们互相调用。
8、面向对象的程序设计方法要求软件系统必须具备三个基本特性:封装性、继承性和多态性。
下面我们来看一个简单的例子,加深一下对这些概念的理解。
请读者帮助我们完善这个示例。
从上面的示例可以看出面向对象的程序设计方法适用于开发大规模软件系统,但是对于我们日常开发小规模程序来说还不够合适,所以我们在这里再来简化一下,并且通过进一步思考和分析,让学生自己来归纳和总结这些设计原则。
请同学们观察上面的例子,哪些符合了面向对象程序设计的启发规则?哪些又不符合?为什么?启发规则在各种各样的软件开发中都有存在,请大家想一想你在学习软件工程的时候,是否也曾经犯过上面的错误呢?在以后的软件工程教学过程中,我们可以利用各种各样的事物作为载体,把这些启发规则作为设计的准则贯穿于整个软件开发的过程当中,让学生能够轻松地掌握这些原则,真正做到举一反三,触类旁通。
3、对象只需要在主体中出现一次,而不需要其它任何操作。
4、主体可以被组合和重用。
5、如果程序中需要用到类或抽象类的话,那么应该尽量不重复使用。
6、如果子类可以扩展父类的功能,那么应该尽量少的使用重复的功能。
迪米特法则原则
迪米特法则原则介绍迪米特法则(Law of Demeter)又称最少知识原则(Principle of Least Knowledge),是面向对象设计中的一条重要原则。
它强调对象之间的松耦合和封装性,旨在降低系统的复杂度和依赖关系。
本文将详细介绍迪米特法则的原理、应用场景以及如何遵循该原则进行设计和开发。
原则解析迪米特法则的核心思想是:一个对象应该尽可能少地了解其他对象的细节,只与其直接的朋友进行通信。
直接的朋友指的是当前对象的成员变量、方法的输入、输出参数中的对象。
迪米特法则要求我们在设计和开发过程中,尽量减少对象之间的交互,降低耦合度,提高系统的可维护性和可扩展性。
迪米特法则的优势遵循迪米特法则可以带来以下优势:1.降低耦合度:对象之间的交互减少,减少了对象之间的依赖关系,降低了耦合度,使系统更加灵活和可维护。
2.提高模块化:对象之间的关系更加清晰,每个对象只需关注与自己相关的内容,提高了模块的独立性和可重用性。
3.增强封装性:对象只需暴露必要的接口,隐藏内部细节,提高了封装性,减少了对外部的影响。
4.易于测试和调试:减少了对象之间的交互,使得测试和调试更加方便,定位问题更加容易。
迪米特法则的应用场景迪米特法则适用于以下场景:1.模块化设计:在模块化设计中,迪米特法则可以帮助我们划分模块的边界,减少模块之间的依赖,提高模块的独立性和可重用性。
2.系统架构:在系统架构设计中,迪米特法则可以帮助我们划分子系统和模块之间的边界,降低子系统和模块之间的耦合度,提高系统的灵活性和可扩展性。
3.面向对象设计:在面向对象设计中,迪米特法则可以帮助我们设计对象之间的关系,降低对象之间的交互,提高对象的封装性和内聚性。
遵循迪米特法则的实践方法遵循迪米特法则的实践方法如下:1.封装数据:将对象的数据封装在对象内部,通过提供公共接口进行访问,避免直接暴露对象的内部细节。
2.限制方法调用:对象之间的方法调用应该尽量少,只调用必要的方法,避免过多的交互和依赖。
软件工程第十一章面向对象设计
THANKS
感谢观看
01
抽象类是一种不能被实例化的 类,它只能被其他类继承。
02
抽象类可以包含抽象方法和具 体方法。抽象方法是没有具体 实现的方法,需要在继承抽象 类的子类中实现。
03
通过继承抽象类,子类可以继 承抽象类的属性和方法,并且 可以重写或实现抽象类中的方 法。
接口与抽象类的选择
在设计软件时,选择使用接口还是抽象类取决于具体需求和设计目标。
关系
关系描述了对象之间的交互和联系。 常见的关系包括关联、聚合和继承。
继承与多态的设计
继承
继承是一种实现代码重用的方式,子类可以继承父类的属性和方法,并可以扩展或覆盖它们。通过继承,可以建 立类之间的层次结构,使得代码更加清晰和易于维护。
多态
多态是指一个接口可以有多种实现方式,或者一个对象可以有多种形态。多态可以提高代码的灵活性和可扩展性, 使得程序更加易于维护和修改。
02
类与对象的设计
类的定义与属性
类的定义
类是对象的抽象,它描述了一组具有相同属性和行为的对象。类定义了对象的结构、行为和关系。
属性
属性是类中用于描述对象状态的变量。每个对象都有其自己的属性值,这些属性值决定了对象的状态 。
对象的行为与关系
行为
行为是类中定义的方法,用于描述对 象可以执行的操作。方法定义了对象 的行为和功能。
高层模块不应该依赖于低层模块,它们都应 该依赖于抽象。
面向对象设计的优势
提高代码可重用性
通过类和继承实现代码重用,减少重 复代码。
提高代码可维护性
面向对象设计使得代码结构更加清晰, 易于理解和维护。
提高开发效率
通过快速原型开发,快速构建软件系 统。
《实用软件工程》第9章 面向对象设计
• 信息隐藏:对于类而言,其内部信息如属性的表示方法和操作的实现算法,对 外界是隐藏的。外界通过有限的接口来访问类的内部信息。
17
9.3.2 面向对象设计的原则
• 低耦合:在面向对象设计中,耦合主要指对象之间相互关联的紧密程度,低耦 合有利于降低一个模块改变对其他模块的影响。
• 高内聚:内聚与耦合密切相关,低耦合往往意味着高内聚,高内聚有助于提高 系统独立性。
但随着需求理解的加深,以及对系统认识程度的逐步 提高,设计人员还要对模型进行修正和完善。 • 设计任务管理子系统包括确定任务,分配任务,还包 括权衡一致性、成本、性能等因素以及未来可扩充性。 • 设计数据管理子系统,需要设计数据格式以及相应的 服务,设计数据格式的方法与所用的数据存储管理模 式密切相关,不同数据存储管理模式时,属性和服务 的设计方法是不同的。
9.2 面向对象设计与面向对象分析的关系
• 设计阶段的任务是及时把分析阶段得到的需求转变成符合各项要求的 系统实现方案。与传统的软件工程方法不同的是,面向对象的方法不强调 需求分析和软件设计的严格区分。实际上,面向对象的需求分析和面向对 象的设计活动是一个反复迭代的过程,从分析到设计的过渡,是一个逐渐 扩充、细化和完善分析阶段所得到的各种模型的过程。严格的意义上来讲, 从面向对象分析到面向对象设计不存在转换问题,而是同一种表示方法在 不同范围的运用。面向对象设计也不仅仅是对面向对象分析模型进行细化。
• (2)人机交互子系统包括有效的人机交互所需的显示和输入,这些类在很大程度上 依赖于所用的图形用户界面环境,例如Windows、Delphi、C++,而且可能包括“窗 口”、“菜单”、“滚动条”、“按钮”等针对项目的特殊类。
25
9.5.1 系统分解
面向对象设计原则实验报告实验01
面向对象设计原则实验报告1.1实验目的1. 通过实例深入理解和掌握所学的面向对象设计原则。
2.熟练使用面向对象设计原则对系统进行重构。
3.熟练绘制重构后的结构图(类图)。
1.2实验内容1.在某绘图软件中提供了多种大小不同的画笔(Pen),并且可以给画笔指定不同颜色,某设计人员针对画笔的结构设计了如图1-1所示的初始类图。
通过仔细分析,设计人员发现该类图存在非常严重的问题,即如果需要增加一种新的大小或颜色的笔,就需要增加很多子类,例如增加一种绿色的笔,则对应每一种大小的笔都需要增加一支绿色笔,系统中类的个数急剧增加。
试根据依赖倒转原则和合成复用原则对该设计方案进行重构,使得增加新的大小或颜色的笔都较为方便,请绘制重构之后的结构图(类图)。
2.在某公司财务系统的初始设计方案中存在如图1-2所示的Employee类, 该类包含员工编号(ID),姓名(name),年龄(age).性别(gender)、薪水(salary)、每月工作时数( workHoursPerMonth),每月请假天数(leaveDaysPerMonth)等属性。
该公司的员工包括全职和兼职两类,其中每月工作时数用于存储兼职员工每个月工作的小时数,每月请假天数用于存储全职员工每个月请假的天数。
系统中两类员工计算工资的万法也不一样,全职员工按照工作日数计算工资﹐兼职员工按照工.作时数计算上资﹐内此在 Employee 类中提供了两个方法calculateSalaryByDays()和calculateSalaryByHours(),分别用于按照大数和时数计算工资,此外,还提供了方法displaySalary()用于显示工资。
试采用所学面向对象设计原则分析图1-2中Employee类存在的问题并对其进行重构绘制重构之后的类图。
3.在某图形界面中存在如下代码片段,组件类之间有较为复杂的相互引用关系:如果在上述系统中增加一个新的组件类,则必须修改与之交互的其他组件类的源代码,将导致多个类的源代码需要修改。
面向对象设计的三大原则,理解并能举例
面向对象设计的三大原则,理解并能举例
面向对象编程设计有三大原则,分别是封装(Encapsulation)、继承(Inheritance)和多态(Polymorphism)。
1. 封装(Encapsulation):封装是将数据和相关行为(方法)
组合在一个类中,以实现隐藏内部实现细节的原则。
通过封装,可以将一组数据和对它们的操作封装在一个类中,对外部只暴露必要的接口,隐藏了实现的细节,提高了代码的安全性和可维护性。
例如,一个汽车类可以封装了颜色、品牌、速度等变量和加速、刹车等方法,对外只提供加速和刹车的接口,而隐藏了内部细节。
2. 继承(Inheritance):继承是指创建一个新类(子类)从已
有的类(父类)中继承属性和方法的过程。
子类可以通过继承父类的特性来扩展和增强功能,并且可以重用已有的代码。
例如,有一个动物类,定义了一些公共属性和方法,然后创建了狗类和猫类继承动物类,狗类和猫类就可以共享动物类的一些功能,同时可以根据需要添加自己的特定功能。
3. 多态(Polymorphism):多态是指同一类对象在不同情况下
可以表现出不同的行为。
对象多态性使用继承和接口实现,通过动态绑定和方法重写,允许不同的对象对同一个方法做出不同的响应。
例如,一个动物类中有一个叫声的方法,猫类和狗类都继承了动物类,并重写了叫声的方法,当通过调用叫声方法时,猫和狗的叫声不同,实现了多态性。
这三个原则是面向对象设计的基石,有助于实现代码的可重用性、可扩展性和灵活性。
面向对象设计原则实验报告实验02
设计模式(2)实验报告一、实验目的1.结合实例,熟练绘制设计模式结构图。
2.结合实例,熟练使用 Java 语言实现设计模式。
3.通过本实验,理解每一种设计模式的模式动机,掌握模式结构,学习如何使用代码实现这些设计模式。
二、实验要求1.结合实例,绘制设计模式的结构图。
2.使用 Java 语言实现设计模式实例,代码运行正确。
三、实验内容1.迭代器模式设计一个逐页迭代器,每次可返回指定个数(一页)元素,并将该迭代器用于对数据进行分页处理。
绘制对应的类图并编程模拟实现。
2.适配器模式某 OA 系统需要提供一个加密模块,将用户机密信息(例如口令、邮箱等)加密之后再存储在数据库中,系统已经定义好了数据库操作类。
为了提高开发效率,现需要重用已有的加密算法,这些算法封装在一些由第三方提供的类中,有些甚至没有源代码。
试使用适配器模式设计该加密模块,实现在不修改现有类的基础上重用第三方加密方法。
要求绘制相应的类图并编程模拟实现,需要提供对象适配器和类适配器两套实现方案。
3.模板方式模式和适配器模式在某数据挖掘工具的数据分类模块中,数据处理流程包括 4 个步骤,分别是:①读取数据;②转换数据格式;③调用数据分类算法;④显示数据分类结果。
对于不同的分类算法而言,第①步、第②步和第④步是相同的,主要区别在于第③ 步。
第③步将调用算法库中已有的分类算法实现,例如朴素贝叶斯分类(Naive Bayes)算法、决策树(DecisionTree)算法、K 最近邻(K-NearestNeighbor , KNN)算法等。
现采用模板方法模式和适配器模式设计该数据分类模块,绘制对应的类图并编程模拟实现。
4.工厂方法模式在某网络管理软件中,需要为不同的网络协议提供不同的连接类,例如针对 POP3 协议的连接类 POP3Connection、针对 IMAP 协议的连接类 IMAPConnection 、针对 HTTP 协议的连接类 HTTPConnection 等。
面向对象设计六大原则
面向对象设计六大原则面向对象设计的原则是面向对象思想的提炼,它比面向对象思想的核心要素更具可操作性,但与设计模式相比,却又更加的抽象,是设计精神要义的抽象概括。
形象地将,面向对象思想像法理的精神,设计原则则相对于基本宪法,而设计模式就好比各式各样的具体法律条文了。
面向对象设计原则有6个:开放封闭原则,单一职责原则,依赖倒置原则,Liskov替换原则,迪米特法则和接口隔离原则或合成/聚合复用原则(不同资料略有不同,这里对7个都做了整理)。
1单一职责原则(Single Responsibility Principle SRP)There should never be more than one reason for a class to change. 什么意思呢?所谓单一职责原则就是一个类只负责一个职责,只有一个引起变化的原因。
如果一个类承担的职责过多,就等于把这些职责耦合在一起,一个职责的变化会削弱或抑制这个类完成其他职责的能力,这个耦合会导致脆弱的设计。
软件设计真正要做的许多内容,就是发现职责并把这些职责相互分离;如果能够想到多于一个动机去改变一个类,那么这个类就具有多于一个职责,就应该考虑类的分离。
以调制解调器为例如下图:从上述类图里面我们发现有四个方法Dial(拨通电话),Hangup(挂电话),Receive(收到信息),Send(发送信息),经过分析不难判断出,实际上Dial(拨通电话)和Hangup(挂电话)是属于连接的范畴,而Receive(收到信息)和Send(发送信息)是属于数据传送的范畴。
这里类包括两个职责,显然违反了SRP。
这样做有潜在的隐患,如果要改变连接的方式,势必要修改Modem,而修改Modem 类的结果导致凡事依赖Modem类可能都需要修改,这样就需要重新编译和部署,不管数据传输这部分是否需要修改。
因此要重构Modem类,从中抽象出两个接口,一个专门负责连接,另一个专门负责数据传送。
面向对象六大基本原则的理解
⾯向对象六⼤基本原则的理解在学习设计模式的时候,总是被推荐先学习⼀下⾯向对象的六⼤原则,学习后果然受益匪浅。
以下完全是我对六⼤基本原则的理解,和官⽹解释可能有出路,⽽且我更多是站在设计模式的⾓度,⽽不是⾯向对象的⾓度理解,如果有什么错误,敬亲谅解。
1.开闭原则很多教程都把开闭原则作为这六⼤原则中最基本的原则,也就是说他是各个原则的核⼼。
开闭原则指的是,⼀个软件实体如类、模块和函数应该对扩展开放,对修改关闭。
⾄于这个具体怎么理解,我也看了很多教程,有些教程说当我们遇到新的需求,就需要我们对我们模块继承的形式进⾏扩展,⽽不是修改代码。
这样的解释貌似有道理,但是如果真的这样做了,程序结构只会更加复杂,业务逻辑只会更不清晰,完全是⼀种作死的做法。
当业务发⽣改变的时候,肯定是要修改代码的,不需要的东西留着只会让程序臃肿,让维护者搞不清什么是有⽤的代码,什么是已经过时的代码。
我不太相信开闭原则的真谛是让我们⾛向这样⼀个死胡同。
对于开闭原则,我的理解是,我们在设计软件的时候,⾸先要搞清楚程序当中什么是未来可能变化的,什么是未来不会变化的。
对于可能变化的东西,我们要提前给与可以对应的扩展接⼝。
当然实际开发中,即便是我们认为这些不会变化的地⽅,未来还是可能变化的,这种变化就只能改代码了,但是这种修改仅仅只是改变个别细节,整体架构往往不会变化。
⽽对于可能变化的地⽅,我们要给出可以⾜够扩展的空间,让其能够⾃由扩展,基本发⽣了重⼤的需求变更,整体架构也不会受影响。
例如:⼯⼚模式中,我们将创建对象的过程封装了起来,这样创建对象对的过程中,创建的代码就和调⽤的代码尽可能地解除了耦合。
创建过程可能是变化的,⽽调⽤过程往往是不变的。
我们创建⼀个对象之后,需要为其初始化,设定⼀些配置,这个过程需要我们给出可以扩展的余地,⽽且要求扩展的时候不能影响调⽤部分,所以需要使⽤⼯⼚模式,将可变的创建过程封装起来,供不变的调⽤模块。
这样说来,开闭原则的核⼼是解耦了?没错,我认为开闭原则讲的就是解构,但是他要求我们在设计的时候,重点要预判出什么地⽅是会发⽣变化的,并要为变化的地⽅留出余地。
面向对象设计七大原则
⾯向对象设计七⼤原则1. 单⼀职责原则(Single Responsibility Principle)每⼀个类应该专注于做⼀件事情。
2. ⾥⽒替换原则(Liskov Substitution Principle)超类存在的地⽅,⼦类是可以替换的。
3. 依赖倒置原则(Dependence Inversion Principle)实现尽量依赖抽象,不依赖具体实现。
4. 接⼝隔离原则(Interface Segregation Principle)应当为客户端提供尽可能⼩的单独的接⼝,⽽不是提供⼤的总的接⼝。
5. 迪⽶特法则(Law Of Demeter)⼜叫最少知识原则,⼀个软件实体应当尽可能少的与其他实体发⽣相互作⽤。
6. 开闭原则(Open Close Principle)⾯向扩展开放,⾯向修改关闭。
7. 组合/聚合复⽤原则(Composite/Aggregate Reuse Principle CARP)尽量使⽤合成/聚合达到复⽤,尽量少⽤继承。
原则:⼀个类中有另⼀个类的对象。
细则单⼀职责原则(Single Responsibility Principle)因为:可以降低类的复杂度,⼀个类只负责⼀项职责,其逻辑肯定要⽐负责多项职责简单的多;提⾼类的可读性,提⾼系统的可维护性;变更引起的风险降低,变更是必然的,如果单⼀职责原则遵守的好,当修改⼀个功能时,可以显著降低对其他功能的影响。
需要说明的⼀点是单⼀职责原则不只是⾯向对象编程思想所特有的,只要是模块化的程序设计,都适⽤单⼀职责原则。
所以:从⼤局上看Android中的Paint和Canvas等类都遵守单⼀职责原则,Paint和Canvas各司其职。
⾥⽒替换原则(Liskov Substitution Principle)因为:⾥⽒替换原则告诉我们,在软件中将⼀个基类对象替换成它的⼦类对象,程序将不会产⽣任何错误和异常,反过来则不成⽴,如果⼀个软件实体使⽤的是⼀个⼦类对象的话,那么它不⼀定能够使⽤基类对象。
面向对象七大基本设计原则
面向对象七大基本设计原则面向对象设计原则是OOPS(Object-Oriented Programming System,面向对象的程序设计系统)编程的核心。
在设计面向对象的程序的时,模式不是一定要套的,但是有一些原则最好是遵守。
这些原则已知的有七个,包括:单一职责原则、开闭原则、里氏代换原则、依赖注入(倒转)原则、接口分离原则、迪米特原则、合成聚合复用原则。
原则一单一职责原则单一职责原则(SRP:Single responsibility principle)又称单一功能原则核心:解耦和增强内聚性(高内聚,低耦合)。
描述:类被修改的几率很大,因此应该专注于单一的功能。
如果你把多个功能放在同一个类中,功能之间就形成了关联,改变其中一个功能,有可能中止另一个功能,这时就需要新一轮的测试来避免可能出现的问题。
原则二里氏替换原则里氏替换原则(LSP:Liskov Substitution Principle)核心:在任何父类出现的地方都可以用他的子类来替代(子类应当可以替换父类并出现在父类能够出现的任何地方)四层含义:(1)子类必须完全实现父类的方法。
在类中调用其他类是务必要使用父类或接口,如果不能使用父类或接口,则说明类的设计已经违背了LSP原则。
(2)子类可以有自己的个性。
子类当然可以有自己的行为和外观了,也就是方法和属性(3)覆盖或实现父类的方法时输入参数可以被放大。
即子类可以重载父类的方法,但输入参数应比父类方法中的大,这样在子类代替父类的时候,调用的仍然是父类的方法。
即以子类中方法的前置条件必须与超类中被覆盖的方法的前置条件相同或者更宽松。
(4)覆盖或实现父类的方法时输出结果可以被缩小。
原则三依赖注入原则依赖注入原则(DIP:Dependence Inversion Principle)别名:依赖倒置原则或依赖反转原则核心:要依赖于抽象,不要依赖于具体的实现三层含义:(1)高层模块不应该依赖低层模块,两者都应该依赖其抽象(抽象类或接口);(2)抽象不应该依赖细节(具体实现);(3)细节(具体实现)应该依赖抽象。
软件工程导论(第11章)
3. 信息隐蔽
在面向对象方法中,信息隐蔽通过对象的封
装性实现:类结构分离了类的接口与类的实
现,从而支持了信息隐蔽。
4. 弱耦合
弱的耦合可以提高软件模块的独立性,避免 某一部分模块发生变化对其它模块有较大的影 响。
一般来说,对象间的耦合有两大类:
A.交互耦合:对象间的耦合通过信息连接来
实现。应使交互耦合尽量松散。
2. 一般—特殊结构的深度应适当
中等规模的系统中,类等级层次数应保持 为7±2。不是必要情况,不应该随意创建派生类;
3. 设计简单的类:设计小而简单的类,便于
开发和管理;
1)避免包含过多的属性; 2)有明确的定义; 3)尽量简化对象之间的合作关系; 4)不要提供太多服务。
4. 使用简单的协议:设计简单的类接口,发送 的消息中参数要少。 5. 使用简单的服务:编写实现每一个服务时, 避免复杂的语句和结构; 6. 把设计变动减至最小。
2.
两个方向的关联都用属性实现,这种方法能 实现快速访问。
3.
用独立的关联对象实现双向关联。关联对象 不属于相互关联的任何一个类,它是独立的 关联类的实例 。
40
41
4、关联对象的实现
关联对象的实现方法取决于关联的阶数:
一对一关联:
• 关联对象可以与参与关联的任一个对象合并。
一对多关联:
• 关联对象可以与“多”端对象合并。
11.9 设计类中的服务 11.9.1 确定类中应有的服务 11.9.2 设计实现服务的方法
1. 设计实现服务的算法
1)算法复杂度;
2)容易理解、容易实现;
3)容易修改;
2. 选择数据结构 3. 定义内部类和内部操作
面向对象六大设计原则
面向对象六大设计原则面向对象编程(Object Oriented Programming,OOP)是一种编程范式,它将代码组织成一系列相互关联的对象,每个对象代表现实世界中的一个实体或概念。
在面向对象编程中,有六大设计原则被广泛认可和遵循,它们是:1. 单一职责原则(Single Responsibility Principle,SRP):一个类应该只有一个引起它变化的原因。
即一个类只负责一个功能领域的相关职责,避免将多个职责集中在一个类中,以提高代码的可维护性和可读性。
2. 开闭原则(Open-Closed Principle,OCP):软件实体(类、模块、函数等)应该对扩展开放,对修改关闭。
即在不修改现有代码的情况下,可以通过扩展来增加新功能,以提高代码的可扩展性和可复用性。
3. 里氏替换原则(Liskov Substitution Principle,LSP):子类型必须能够替换它们的父类型。
即在继承关系中,子类可以替换父类在代码中的位置,而不会导致程序出现错误。
4. 接口隔离原则(Interface Segregation Principle,ISP):不应该强迫客户依赖于他们不使用的接口。
即在设计接口时,应该将不同的功能隔离开来,避免接口过于庞大和复杂。
5. 依赖倒置原则(Dependency Inversion Principle,DIP):高层模块不应该依赖于底层模块,二者都应该依赖于抽象。
即在代码设计中,应该依赖于抽象而不是具体实现,以提高代码的灵活性和可复用性。
6. 迪米特法则(Law of Demeter,LoD):一个对象应该对其他对象保持最少的了解。
即在代码设计中,应该尽量减少对象之间的耦合,只暴露必要的接口和方法,以提高代码的可维护性和可复用性。
这些设计原则旨在帮助开发者编写高质量、可维护、可扩展的代码。
在实际编程中,遵循这些原则可以提高代码的可读性、可复用性和可维护性,降低代码的耦合度,提高系统的灵活性和可扩展性。
软件设计师(基础知识、应用技术)合卷软件资格考试(中级)试卷与参考答案(2025年)
2025年软件资格考试软件设计师(基础知识、应用技术)合卷(中级)自测试卷(答案在后面)一、基础知识(客观选择题,75题,每题1分,共75分)1、面向对象设计的基本原则是什么?2、在面向对象设计中,哪个设计模式被称为“工厂方法模式”?3、在面向对象设计中,以下哪个不是面向对象的基本特性?A. 封装B. 继承C. 多态D. 过载4、在UML中,用于表示系统中的静态结构的图是:A. 类图B. 用例图C. 时序图D. 协作图5、题目:简述软件生命周期模型的V模型,并说明该模型的主要特点。
6、题目:简述软件需求规格说明书的内容和作用。
5.非功能需求:说明软件的产品特性,例如性能、安全性、可靠性等。
6.系统接口:描述软件与用户、硬件、其他系统之间的交互方式。
7.设计约束:说明软件在开发过程中需要遵守的限制条件。
作用:1.指导软件开发:SRS是软件开发的重要依据,为开发团队提供明确的指导,确保软件产品符合用户需求。
2.项目管理: SRS是项目管理的基准,可以帮助项目经理监控项目的进展和质量。
3.沟通桥梁: SRS是项目团队、客户和用户之间的沟通桥梁,确保各方的需求得到充分理解和沟通。
4.验收标准: SRS可以作为软件产品验收的依据,确保软件产品满足预期需求。
解析:软件需求规格说明书是软件开发过程中不可或缺的文档,对项目成功具有重要意义。
编写高质量的SRS需要充分了解用户需求、业务场景和相关技术,以确保软件产品的可行性和可行性。
7、题干:在面向对象程序设计中,封装是指将数据和操作数据的方法捆绑在一起,以下关于封装的说法中,错误的是()A. 封装可以隐藏对象内部实现细节,提高系统的安全性B. 封装可以减少模块间的依赖性,提高模块的独立性C. 封装可以提高代码的可重用性,降低维护成本D. 封装会降低代码的可读性8、题干:在软件工程中,需求分析是软件开发过程中的重要阶段,以下关于需求分析的说法中,错误的是()A. 需求分析的主要任务是确定软件系统必须做什么B. 需求分析的结果是需求规格说明书C. 需求分析阶段不需要与用户沟通D. 需求分析阶段应考虑系统的可行性9、下列关于对象的描述中,哪个是错误的?A. 对象是类的一个实例B. 对象具有封装性,可以隐藏内部实现细节C. 对象之间的交互通过消息传递实现D. 所有对象必须直接或间接地派生自System.Object 10、在编程中,什么是多态?A. 一个接口被多个类实现B. 在运行时根据对象的实际类型来确定调用哪个方法C. 一个类有一个以上的子类D. 一个方法或操作在不同对象中有不同的实现方式11、以下哪种设计模式不适用于实现层次结构,因为它强调的是对象之间的组合而不是继承?()A. 组合模式(Composite Pattern)B. 装饰模式(Decorator Pattern)C. 策略模式(Strategy Pattern)D. 迭代器模式(Iterator Pattern)12、在软件开发中,以下哪个阶段不是软件简历生命周期的一部分?()A. 需求分析B. 系统设计C. 编码D. 测试13、以下关于软件工程中软件复用的说法,哪项是错误的?A. 软件复用是指将已有的软件组件或代码片段用于新的软件开发过程中B. 软件复用可以提高软件开发效率和质量C. 软件复用可以降低软件的维护成本D. 软件复用可能导致软件质量下降14、在软件生命周期中,以下哪个阶段是对软件需求进行分析和定义的阶段?A. 软件设计阶段B. 软件编码阶段C. 软件需求分析阶段D. 软件测试阶段15、在软件工程中,软件产品文档化的各个环节被划分为不同的活动,这些活动按照一定的顺序进行,这样的顺序被称为文档生命周期。
面向对象数据库系统中的索引设计与优化
面向对象数据库系统中的索引设计与优化在面向对象数据库系统中,索引是一项重要的组织和优化数据存储和访问的技术。
索引的设计和优化对于提高数据库的性能和效率具有关键性的影响。
本文将探讨面向对象数据库系统中索引的设计原则、常见优化技术以及如何选择适当的索引类型。
一、索引设计原则1. 唯一性:索引字段应该具有唯一性,确保每个索引值都是唯一的。
这可以通过为索引字段添加主键约束或唯一约束来实现。
2. 关键性:索引字段应该是关键字段,即经常被用于查询和排序的字段。
通常,与频繁出现在where子句或order by子句中的字段相关联的索引可以提升查询性能。
3. 多列索引:对多个字段进行组合索引,可以进一步提高查询效率。
但是,需要权衡索引的长度和查询的复杂性。
不宜过多的组合索引,以避免索引冗余。
4. 选择合适的数据结构:根据具体的需求和数据特点,选择合适的索引数据结构。
常用的索引数据结构包括B树、B+树和哈希索引。
B树适用于范围查询,B+树适用于范围查询和排序,哈希索引适用于等值查询。
二、索引优化技术1. 索引覆盖(Covering Index):通过创建包含所有需要的查询字段的索引,可以避免查询操作需要访问主表的磁盘块。
这样可以大大减少磁盘访问次数,提高查询性能。
2. 索引分区(Index Partitioning):将大型索引分割成多个较小的索引分区,可以提高索引的维护效率。
每个分区可以独立地进行维护操作,减小了锁竞争和资源争用。
3. 索引压缩(Index Compression):通过对索引数据进行压缩,可以减少磁盘空间的占用,提高索引读取速度。
常见的索引压缩算法有前缀压缩、字典压缩和位图压缩。
4. 索引碎片整理(Index Defragmentation):索引在进行增删改操作后可能会产生碎片,导致索引树结构不连续,降低了查询性能。
通过定期进行索引碎片整理,可以提高索引的连续性和性能。
三、选择适当的索引类型1. 普通索引(Normal Index):普通索引可以加快查询的速度,但不对数据的唯一性进行强制规定。
Java面向对象设计的六大原则
Java⾯向对象设计的六⼤原则这是设计模式系列开篇的第⼀篇⽂章。
也是我学习设计模式过程中的总结。
这篇⽂章主要讲的是⾯向对象设计中,我们应该遵循的六⼤原则。
只有掌握了这些原则,我们才能更好的理解设计模式。
我们接下来要介绍以下6个内容。
单⼀职责原则——SRP开闭原则——OCP⾥式替换原则——LSP依赖倒置原则——DIP接⼝隔离原则——ISP迪⽶特原则——LOD单⼀职责原则单⼀职责原则的定义是就⼀个类⽽⾔,应该仅有⼀个引起他变化的原因。
也就是说⼀个类应该只负责⼀件事情。
如果⼀个类负责了⽅法M1,⽅法M2两个不同的事情,当M1⽅法发⽣变化的时候,我们需要修改这个类的M1⽅法,但是这个时候就有可能导致M2⽅法不能⼯作。
这个不是我们期待的,但是由于这种设计却很有可能发⽣。
所以这个时候,我们需要把M1⽅法,M2⽅法单独分离成两个类。
让每个类只专⼼处理⾃⼰的⽅法。
单⼀职责原则的好处如下:可以降低类的复杂度,⼀个类只负责⼀项职责,这样逻辑也简单很多提⾼类的可读性,和系统的维护性,因为不会有其他奇怪的⽅法来⼲扰我们理解这个类的含义当发⽣变化的时候,能将变化的影响降到最⼩,因为只会在这个类中做出修改。
开闭原则开闭原则和单⼀职责原则⼀样,是⾮常基础⽽且⼀般是常识的原则。
开闭原则的定义是软件中的对象(类,模块,函数等)应该对于扩展是开放的,但是对于修改是关闭的。
当需求发⽣改变的时候,我们需要对代码进⾏修改,这个时候我们应该尽量去扩展原来的代码,⽽不是去修改原来的代码,因为这样可能会引起更多的问题。
这个准则和单⼀职责原则⼀样,是⼀个⼤家都这样去认为但是⼜没规定具体该如何去做的⼀种原则。
开闭原则我们可以⽤⼀种⽅式来确保他,我们⽤抽象去构建框架,⽤实现扩展细节。
这样当发⽣修改的时候,我们就直接⽤抽象了派⽣⼀个具体类去实现修改。
⾥⽒替换原则⾥⽒替换原则是⼀个⾮常有⽤的⼀个概念。
他的定义如果对每⼀个类型为T1的对象o1,都有类型为T2的对象o2,使得以T1定义的所有程序P在所有对象o1都替换成o2的时候,程序P的⾏为都没有发⽣变化,那么类型T2是类型T1的⼦类型。
软件工程第11章面向对象设计
2. 重用已有的类
重用已有类(代码重用)实现分析模型;若没有可以重用类而需要创建新 类时,则在设计这些新类时需要考虑其可重用性。
对于已有的可重用类,典型重用方法和过程如下: 1)选择可能被重用的已有类,标出类中对本问题无用的属性和服务,选 择那些能使无用的属性和服务最少的类; 2)从被重用的已有类派生出问题域类(继承重用类而产生问题域类); 3)标出从已有类继承来的属性和服务,而无须在分析类内定义;
6. 可重用
软件重用是提高软件开发生产率和目标系统质量的重要途径。 重用有两方面的含义: 一是尽量使用已有的类(类库或已建立的类), 二是如果确实需要创建新类,则在设计这些新类的协议时,应该考虑将 来的可重复使用性。
11.2
启发规则
与结构设计规则类似,通过OOD实践也总结了一些设计规则: 1. 设计结果应该清晰易懂 设计结果清晰、易读、易懂,是提高软件可维护性和可重用性的重要 措施。保证设计结果清晰易懂的主要因素为:用词一致;使用已有的 协议;避免模糊的定义等。
1)层次组织:这种组织方案把软件系统组织成一个层次系统,每层是一 个子系统。上层和下层自系统形成C/S结构 层次结构的两种模式:封闭式和开放式:封闭式,每层子系统仅仅使用其 直接下层提供的服务;开放式,任一层次可以向下跨层次调用。 2)块状组织:把软件系统垂直地分解成若干个相对独立的、松耦合的子 系统,一个子系统相当于一块,每块提供一种类型的服务。
第11章
11.1 11.2 11.3 11.4 11.5 11.6 11.7 11.8 11.9 11.10 11.11
面向对象设计
面向对象设计的准则 启发规则 软件重用 系统分解 设计问题域子系统 设计人机交互子系统 设计任务管理子系统 设计数据管理子系统 设计类中的服务 设计关联 设计优化
面向对象设计的七大原则
⾯向对象设计的七⼤原则在上⼀篇⾥我们谈了谈为何设计模式,那接下来我们再浅谈⼀下在⾯向对象设计中我们常常要遵循的⼀些原则。
这些原则是经过⽆数的前⼈总结出来的经验的结晶。
仅仅有遵循这些原则。
你才有可能涉及出优秀的代码。
今天我们要谈的原则有七⼤原则,即:单⼀职责。
⾥⽒替换。
迪⽶特法则,依赖倒转,接⼝隔离,合成/聚合原则。
开放-封闭。
1. 开闭原则定义:软件实体应当对扩展开放,对改动关闭。
这句话说得有点专业。
更通俗⼀点讲,也就是:软件系统中包括的各种组件,⽐如模块(Modules)、类(Classes)以及功能(Functions)等等。
应该在不改动现有代码的基础上。
去扩展新功能。
开闭原则中“开”。
是指对于组件功能的扩展是开放的。
是同意对其进⾏功能扩展的。
开闭原则中“闭”。
是指对于原有代码的改动是封闭的,即不应该改动原有的代码。
问题由来:凡事的产⽣都有缘由。
我们来看看。
开闭原则的产⽣缘由。
在软件的⽣命周期内,由于变化、升级和维护等原因须要对软件原有代码进⾏改动时。
可能会给旧代码中引⼊错误,也可能会使我们不得不正确整个功能进⾏重构,⽽且须要原有代码经过⼜⼀次測试。
这就对我们的整个系统的影响特别⼤。
这也充分展现出了系统的耦合性假设太⾼,会⼤⼤的添加后期的扩展。
维护。
为了解决问题,故⼈们总结出了开闭原则。
解决开闭原则的根本事实上还是在解耦合。
所以。
我们⾯向对象的开发,我们最根本的任务就是解耦合。
解决⽅法:当软件须要变化时。
尽量通过扩展软件实体的⾏为来实现变化。
⽽不是通过改动已有的代码来实现变化。
⼩结:开闭原则具有理想主义的⾊彩。
说的⾮常抽象,它是⾯向对象设计的终极⽬标。
其它⼏条原则,则能够看做是开闭原则的实现。
我们要⽤抽象构建框架,⽤实现扩展细节。
2. 单⼀职责原则(Single Responsibility Principle)定义:⼀个类。
仅仅有⼀个引起它变化的原因。
即:应该仅仅有⼀个职责。
每个职责都是变化的⼀个轴线。
面向对象设计的三个基本要素
面向对象设计的三个基本要素面向对象的三个基本特征是:封装、继承、多态。
1·封装性封装性是一种信息隐蔽技术,他体现于类的说明,是对象重要的特性。
封装使得数据和操作数据的方法封装为一个整体,想成独立性很强的模块,使得用户只能看到对象的外部特性(对象可以接受拿些信息,可以进行何种处理),而对象的内部特性(内部私有属性和实现处理能力的算法)用户是看不到的。
简而言之就是说,封装使对象的设计者与对象的使用者分开,使用者只要知道对象可以做什么就可以了,无需知道具体是怎么实现的。
借助封装有助于提高类和系统的安全性。
2·继承性继承是一种由已有类创建子类的机制,利用继承,可以先创建一个共有属性的一般类,根据这个类再创建具有特殊属性的子类,被继承的类成为父类,当然子类也可以成为父类来继续向下扩展。
3·多态性同一个信息被不同的对象接收到时可能产生不同的行为,这就是多态性。
有继承(接口)有重写,父类引用指向子类对象,就会产生多态。
多态可以改善程序的组织架构,提高程序的可扩展性。
二、面向对象设计的五个基本设计原则面向对象设计的五个基本设计原则是:单一职责原则(SRP)、开放封闭原则(OCP)、Liskov替换原则(LSP)、依赖倒置原则(DIP)、接口隔离原则(ISP)1·单一职责原则(Single-Responsibility Principle)其核心思想为:一个类只做一件事情,只有一个引起他的变化。
单一职责原则可以看做是低耦合,高内聚在面向对象原则上的隐身,将职责定义为引起变化的原因,以提高内举行来减少引起变化的原因。
职责过多可能引起他变化的原因也就越多,这将导致职责依赖,相互之间产生影响,从而大大损伤内聚性和耦合度。
单一职责就是指,只有一种单一的功能,不要为类实现过多的功能点,有些功能可以定义为接口来实现,以保证只有一个引起他变化的原因。
专注是一个人优良的品质。
同样的,单一也是一个类的优良设计,杂交不清的职责将使得代码看起来特别别扭,牵一发动全身,有失没敢和必然导致丑陋的系统错误风险。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
面向对象七大设计原则
1、开闭原则
2、里氏替换原则
3、单一职责原则
4、接口隔离原则
5、依赖倒置原则
6、迪米特原则
7、组合/聚合复用原则
知识点关联
学习面向对象的设计模式,是深入面向对象思想的钥匙,通过大师级的微妙案例,我们可以开阔自己的认知。
在学习面向对象设计七大原则之前,我们要对基本的封装、继承、多态思想有足够的了解,对抽象类和接口也要有足够的编码能力,因为设计模式是以上知识点的综合应用。
另外,在接触具体的设计模式之前,面向对象的七大设计原则会让你知道,设计模式出现的必然性和意义所在。
1、每一种设计思想的精准含义,具体如下:
先从整体认识这七种设计思想。
一、开闭原则:
这一条放在第一位来理解,它的含义是对扩展开放,对修改关闭。
解释一下就是,我们写完的代码,不能因为需求变化就修改。
我们可以通过新增代码的方式来解决变化的需求。
当然,这是一种理想的状态,在现实中,我们要尽量的缩小这种修改。
再解释一下这条原则的意义所在,我们采用逆向思维方式来想。
如果每次需求变动都去修改原有的代码,那原有的代码就存在被修改错误的风险,当然这其中存在有意和无意的修改,都会导致原有正常运行的功能失效的风险,这样很有可能会展开可怕的蝴蝶效应,使维护工作剧增。
说到底,开闭原则除了表面上的可扩展性强以外,在企业中更看重的是维护成本。
所以,开闭原则是设计模式的第一大原则,它的潜台词是:控制需求变动风险,缩小维护成本。
以下几种原则,都是为此原则服务的。
二、里氏替换选择:
此原则的含义是子类可以在任何地方替换它的父类。
解释一下,这是多态的前提,我们后面很多所谓的灵活,都是不改变声明类型的情况下,改变实例化类来完成的需求变更。
当然,继承的特性看似天然就满足这个条件。
但这里更注重的是继承的应用问题,我们必须保证我们的子类和父类划分是精准的。
里氏替换原则的潜台词是:尽量使用精准的抽象类或者接口。
三、单一职责原则:
单一职责的含义是:类的职责单一,引起类变化的原因单一。
解释一下,这也是灵活的前提,如果我们把类拆分成最小的职能单位,那组合与复用就简单的多了,如果一个类做的事情太多,在组合的时候,必然会产生不必要的方法出现,这实际上是一种污染。
举个例子,我们在绘制图案的时候,用“点”组成图和用“直线”组成图,哪个更灵活呢?一定是“点”,它可以绘制任何图形,而直线只能绘制带有直线条的图案,它起码无法画圆。
单一职责的潜台词是:拆分到最小单位,解决复用和组合问题。
四、接口隔离原则:
接口隔离原则可以说是单一职责的必要手段,它的含义是尽量使用职能单一的接口,而不使用职能复杂、全面的接口。
很好理解,接口是为了让子类实现的,如果子类想达到职能单一,那么接口也必须满足职能单一。
相反,如果接口融合了多个不相关的方法,那它的子类就被迫要实现所有方法,尽管有些方法是根本用不到的。
这就是接口污染。
接口隔离原则的潜台词是:拆分,从接口开始。
五、依赖倒置原则:
想要理解依赖倒置原则,必须先理解传统的解决方案。
面相对象的初期的程序,被调用者依赖于调用者。
也就是调用者决定被调用者有什么方法,有什么样的实现方式,这种结构在需求变更的时候,会付出很大的代价,甚至推翻重写。
依赖倒置原则就是要求调用者和被调用者都依赖抽象,这样两者没有直接的关联和接触,在变动的时候,一方的变动不会影响另一方的变动。
其实,依赖倒置和前面的原则是相辅相成的,都强调了抽象的重要性。
依赖倒置的潜台词是:面向抽象编程,解耦调用和被调用者。
六、迪米特原则:
迪米特原则要求尽量的封装,尽量的独立,尽量的使用低级别的访问修饰符。
这是封装特性的典型体现。
一个类如果暴露太多私用的方法和字段,会让调用者很茫然。
并且会给类造成不必要的判断代码。
所以,我们使用尽量低的访问修饰符,让外界不知道我们的内部。
这也是面向对象的基本思路。
这是迪米特原则的一个特性,无法了解类更多的私有信息。
另外,迪米特原则要求类之间的直接联系尽量的少,两个类的访问,通过第三个中介类来实现。
迪米特原则的潜台词是:不和陌生人说话,有事去中介。
七、组合/聚合复用原则:
此原则的含义是,如果只是达到代码复用的目的,尽量使用组合与聚合,而不是继承。
这里需要解释一下,组合聚合只是引用其他的类的方法,而不会受引用的类的继承而改变血统。
继承的耦合性更大,比如一个父类后来添加实现一个接口或者去掉一个接口,那子类可能会遭到毁灭性的编译错误,但如果只是组合聚合,只是引用类的方法,就不会有这种巨大的风险,同时也实现了复用。
组合聚合复用原则的潜台词是:我只是用你的方法,我们不一定是同类。
2、在学习面向对象七大设计原则时需要注意以下几点:
a)高内聚、低耦合和单一职能的“冲突”
实际上,这两者是一回事。
内聚,要求一个类把所有相关的方法放在一起,初看是职能多,但有个“高”,就是要求把联系非常紧密的功能放在一起,也就是说,从整体看,是一个职能的才能放在一起,所以,两者是不同的表述而已。
这里很多人理解成复合类,但复合类不是高内聚,而是杂乱的放在一起,是一种设计失误而已。
b)多个单一职能接口的灵活性和声明类型问题
如果一个类实现多个接口,那么这个类应该用哪个接口类型声明呢?应该是用一个抽象类来继承多个接口,而实现类来继承这个接口。
声明的时候,类型是抽象类。
c)最少知识原则和中介类泛滥两种极端情况
这是另一种设计的失误。
迪米特原则要求类之间要用中介来通讯,但类多了以后,会造成中介类泛滥的情况,这种情况,我们可以考虑中介模式,用一个总的中介类来实现。
当然,设计模式都有自己的缺陷,迪米特原则也不是十全十美,交互类非常繁多的情况下,要适当的牺牲设计原则。
d)继承和组合聚合复用原则的“冲突”
继承也能实现复用,那这个原则是不是要抛弃继承了?不是的。
继承更注重的是“血统”,也就是什么类型的。
而组合聚合更注重的是借用“技能”。
并且,组合聚合中,两个类是部分与整体的关系,组合聚合可以由多个类的技能组成。
在C#和Java中只有单继承。
这个原则不是告诉我们不用继承了,都用组合聚合,而是在“复用”这个点上,我们优先使用组合聚合。
面向对象设计原则的共性问题:
1、这么多设计模式,都要学习和使用么?
答:我们只是掌握总体的原则,然后学习常用的就行了。
实际开发中也不是每种设计模式都会经常用到。
因为归根结底,设计模式也好,架构也好,都是为需求服务的,没有需求业务模型,不能生搬硬套模式。
我们在学习的时候,多学一些总是好的,但只是为了开阔自己的眼界。
2、设计模式是规范么?是不是好的程序必须用设计模式?
答:严格来说,好的程序遵循的是设计原则,而非设计模式。
现在就出现很多新的演变出来的模式,这些都是因为出现了新业务的原因,设计模式不是规范,只是一种借鉴。
3、使用设计模式会不会增加开发难度?
答:开发阶段会的,而且会延长开发时间。
但一个项目或产品从开始到结束,开发只是其中很小的一部分,考虑到维护和扩展成本,才会出现设计模式。
从整体考虑,设计模式是减少了开发时间和成本的。