首页 > 编程知识 正文

软考考点查询,软考中级

时间:2023-05-04 12:21:11 阅读:109818 作者:2217

软考(软件设计师)考点总结:https://blog.csdn.net/Lzy410992/article/details/117321579

面向对象的基本概念

面向对象的分析:认证对象、组织对象、记述对象之间的相互关系、定义对象操作、定义对象的内部消息

采用分析过程中:名词短语识别对象、动词短语识别对象操作。

对象是基本的运行实体,它既包括数据(属性),也包括作用于数据的操作(行为)。

对象的状态:用于标识对象的所有属性以及每个属性的当前值。

行为:受众根据其状态和消息传递采取的行动和反应

操作:类提供提供它的对象的服务

封装:使对象的使用者和对象的生产者分离的信息隐藏技术。 通过组件提供功能和接口,开发者不需要知道使用的软件组件内部的工作原理,只需要知道组件接口的使用方法。

继承:类的定义和实现可以基于已经存在的类来执行。

一种模仿现实世界继承关系的关系,是父类(超类)和子类之间共享数据的方法和机制。 父类可以有多个子类,子类可以继承为自己的内容,而无需重新定义父类或祖先类的属性或操作,也可以复盖这些操作并添加新内容。

覆盖:子类提供了一种更具体的从父类继承的方法

多重继承:一个类可以继承另一个类,另一个类可以继承另一个类。 多重继承可能导致混淆,出现二义成员。

多态:根据多个状态,即接口的安装方法,例如在游戏中不同的角色发起攻击具有不同的效果。 多态的实现由继承支持,利用类继承的层次关系,将具有共同功能的消息存储在较高层次,将实现不同功能的行为置于较低层次。 当某个对象发送通用消息服务时,根据接收对象的情况,连接所需的操作和实现方式,即进行动态绑定,对这些低级别的转发消息实现不同的响应。

通过采用参数多态(静态多态):参数化模板,给出不同类型的参数,一个结构有多种类型

包含多态(属于动态多态):存在于许多语言中,最常见的例子是子类型泛化。 这意味着一个类型是另一个类型的子类型。

过载多态(属于静态多态):即使是相同的名字,根据上下文的不同意思也不同。 例如,运算符重载、函数重载

强制多态(属于静态多态):编译器通过语义操作强制变换操作对象的类型以满足函数或操作员的要求。

接口:操作不需要自己实现,而是实现类需要实现的特殊抽象机制。 如果实现类是抽象类,则可以将操作保留为抽象。 如果实现类是具体类,则该操作必须实现。

消息:不同类别的对象通过消息传递相互通信

绑定:面向对象系统中,绑定是一个把过程调用和响应调用需要执行的代码加以结合的过程。

静态绑定:编译时进行的绑定

动态绑定:运行时进行的绑定。

重载:在一个类中,函数或方法具有相同的名称和单个参数的列表。

依赖:

泛化:一个类与其一个或多个精化类的关系

组合:整体负责该部分的制作和废弃,如果整体不存在,则部分也不存在的聚合关系。

聚合:较大的全局类包含一个或多个较小的子类

设计原则:

设计模式

设计模式的基本分类:

创建图案用于创建对象的图案

抽象工厂模式(Abstract Factory) :提供了一个在不指定特定类的情况下创建相关或依赖对象的接口。

构建器/生成器模式(Builder) :分离复杂对象的构建及其表示,以便可以在同一构建过程中创建不同的表示。

定义用于创建工厂方法模式(Factory Method) :对象的接口,以便子类可以决定实例化哪个类。 将类的实例化延迟到子类。

使用原型模式(Prototype) :原型实例指定要创建的对象类型,然后通过复制这些原型来创建新对象。

单例模式(

Singleton) : 保证一个类仅有一个实例,并提供一个访问它的全局访问点。

结构型模式

主要处理类和对象的组合问题,让类或对象形成更大的结构提供相应的指导

适配器模式(Adapter) : 将一个类的接口转换成客户希望的另外一个接口。使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。

桥接模式(Bridge) : 将抽象部分与其实现部分分离,使它们可以独立地变化。

组合模式(Composite) : 将对象组合成树形结构以表示“部分-整体”的层次结构,使得用户对单个对象和组合对象的使用具有一致性。

装饰模式(Decorator) : 对对象进行包装,动态地给一个对象添加一些额外的职责。(给对象添加行为)

外观模式(Facade) : 为子系统中的一组接口提供一个一致的界面。定义了一个高层接口,这个接口使得这一子系统更加容易使用。(简化接口)

享元模式(Flyweight) : 运用共享技术有效地支持打两细粒度的对象。 (对象共享)

代理模式(Proxy) : 为其他对象提供一种代理以控制对这个对象的访问。

行为型模式

主要描述类或对象交互的情况以及职责的分配问题。

责任链模式(Chain of Responsibility) : 使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系。将这些对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理它为止。

命令模式(Command) : 将请求封装为一个对象,从而使得可以用不同的请求对客户进行参数化;对请求排队或记录请求日志,以及支持可撤销的操作。

解释器模式(Interpreter) : 给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子。(用来表示解释语言)

迭代器模式(Iterator) : 提供一种方法顺序访问一个聚合对象中的各个元素,且不需要暴露该对象的内部表示。

中介者模式(Mediator) : 用一个中介对象来封装一系列的对象交互。使各对象不需要显式地相互引用,从而使耦合松散,而且可以独立地改变它们之间的交互。(中介对象封装对象交互)

备忘录模式(Memento) : 在不破坏封装性的前提下,捕获一个对象的内部状态,并在对象之外保存这个状态。这样以后就可以将对象恢复到原先保存的状态。

观察者模式(Observer) : 定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都能得到通知,并被自动更新。 (通知所有依赖对象)

状态模式(State) : 允许一个对象在其内部状态改变时改变它的行为。

策略模式(Strategy) : 定义一系列的算法,把它们一个个封装起来,并且使它们可以相互替换。(封装算法)

模板方法(Template Method) : 定义一个操作中的算法骨架,而将一些步骤延迟到子类中。使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。

访问者模式(Visitor) : 标识一个作用内向的唇彩对象结构中的各元素的操作,它允许在不改变各元素的类的前提下定义作用于这些元素的新操作。

UML

UML:一种面向对象软件的标准化建模语言,由三个要素构成:UML的基本构造快、支配这些构造快如何放置在一起的规则、运用与整个语言的一些公共机制。

UML词汇表由三部分组成:事物、关系和图
事物: 对模型中最具有代表性的成分抽象
关系: 包括依赖、关联、泛化、实现
图: 聚集了相关的事物

四种事物:
结构事物:模型中的名词,通常是模型的静态部分,描述概念或物理元素,包括:类、接口、协作、用例、主动类、构件、制品和结点
行为事物:UML模型中的动态部分,是模型中的动词,描述了跨越时间和空间的行为。包括:交互、状态机、活动。
分组事物:UML模型的组织部分,是一些由模型分解成的盒子。例如:包
注释事物:UML模型的解释部分。这些注释事物用来描述、说明和标注模型的任何元素。例如:注解

依赖:两个事物间的语法关系,其中一个事物发生变化会影响另一个事物的语义。
泛化:一种特殊/一般关系,特殊元素的对象可以替代一般元素的对象,用这种方法,子元素共享父元素的结构和行为。
关联:一种结构关系,它描述了一个组链,组链是对象之间的连接。
实现:类元之间的语义关系,其中一个类元指定了由另一个类元保证的契约。

用例图: 描述一组用例、参与者以及它们的关系(包含关系、扩展关系、泛化关系),主要支持系统的行为,即系统在它的周边环境的语境中所提供的外部可见服务。
用例图用于对一个系统的需求进行建模,说明这个系统应该做什么,而不考虑应该怎么做。

类图: 展现一组对象、接口、协作和它们之间的关系。(一种静态设计视图)
对象图:展现某一时刻一组对象以及它们之间的关系。用来描述类图中所建立的事物的实例和静态快照。
1:一个集合一个对象对应一个集合一个对象、
0..*:一个集合一个对象对应另一个集合中0个或多个对象
1..*或*:一个集合一个对象对应另一个集合中1个或多个对象

顺序图(时序图): 以二维图形的形式显示对象之间交互的图,主要体现体现对象间消息传递的时间顺序,强调参与交互的对象及其间消息交互的时序。
包括:活动者、对象、生命线、控制焦点、和消息等。

状态图: 描述一个状态机,由状态、事件和活动组成。给出了对象的动态视图。

活动图: 展现了在系统内从一个活动治动到另一个活动的流程,专注于系统的动态视图。一般包括:活动状态、动作状态、转换和对象。

通信图(协作图): 一种交互图,描述对象与对象之间的关系,以一个类操作的实现。对象、链接、消息

构件图: 用来表示系统中构件与构件之间,类或接口与构件之间的关系图,由源代码文件、二进制代码文件、可执行文件、或动态链路库等构件构成,并通过依赖关系相连接。表示系统的静态设计实现图。
部署图: 对面向对象系统的物理方面建模的方法,展现了运行时处理结点以及其中构件的配置。

系统领域建模:类图
物理方面建模:部署图、构件图
交互关系建模:顺序图、交互概念图
复杂用例建模:活动图

UML模型:

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。