三个编程思想:面向对象编程、面向接口编程、面向过程编程【概念解析系列_1】【C# 基础】

发布时间 2023-07-29 23:25:45作者: 橙子家

〇、前言

对于 .Net 中的编程思想还是十分重要的,也是编码出高效的程序的基础!

在使用之前了解其本质,那么用起来就游刃有余。下面来简单对比下三个编程思想,看下它们都是什么,它们之间又有什么关系。

一、对象、接口、过程

稍等,在介绍主角之前呐,先来了解下它们思想的基础是怎么回事。

对象

  万事万物皆为对象。我们生活中的每一件东西都可以看作是一个对象,包括我们本身都是一个对象。

  这是一种抽象的思想,我们将一件事物提取出特征和行为,将特征定义为属性,将行为封装成方法

  如,一个人,特征有姓名、年龄、性别、职业等等,行为有吃饭、睡觉、学习等等。

接口

  接口声明了属性、方法和事件,这些都是接口的成员。

  在 C# 8.0 之前,接口只包含成员的声明而不关心成员的实现,只是提供派生类实现的标准结构。在此之后时代变了,接口也可以拥有自己的带实现的方法,而且在未实现此方法的派生类中不能调用。

过程

  顾名思义,就是广义上的一件事,通过一系列对象,按照顺序,执行一系列动作,从开始到完成的集合。

二、简介与示例

1.1 面向对象编程

面向对象编程(Object Oriented Programming:OOP),侧重点在对象,解决一个问题时,先将问题中的包含的事物抽象成对象概念,对象中包含具体的属性和行为,真正执行时再让每个对象去执行自己的某些方法,从而解决问题。

举个例子说明:

就拿日常洗手这个流程吧,简单点,水冲一下就好。

其中涉及的对象有:手、水龙头、水、毛巾。

  • 针对“手”这个对象,有 5+5=10 根手指等属性,以及“开水龙头”“关水龙头”“洗”等动作,对应的就是方法。
  • 针对“水龙头”这个对象,有开关、出水口等属性,以及“流出水”等动作。

然后就是执行:

  • 手对象进行开水龙头动作,
  • 水龙头对象进行流出水动作,
  • 手对象进行洗动作,
  • 手对象进行关水龙头动作,洗手过完成。

通过上边的例子知道,面向对象编程的方式,就是先将事件中的实体抽象成具体的对象,然后再将属性和方法封装到对象中,最后通过不同的对象执行相应的方法完成事件。

1.2 面向过程编程

面向过程编程(Procedure Oriented Programming:POP),侧重点在过程。解决一个事件的时候,先分析出处理这个事件需要的步骤,然后使用方法将这些步骤一步步实现,然后处理事件的时候,按照一定的顺序执行这些方法,全部执行一遍后事件就完成了。

还是上边那个洗手的例子:

面向过程,就需要先把吸收这个事件分步骤:

  • 打开水龙头,
  • 水龙头流水,
  • 洗手动作开始,
  • 关闭水龙头。

通过以上四步,完成洗手这个事件。

通过上边的例子知道,面向过程编程的思想在处理事件时,将整个事件拆分成一个个步骤,每个步骤封装成对应的函数,然后按照某个顺序去执行,来完成事件。

1.3 面向接口编程

面向接口编程(Interface Oriented Programming:OIP)是一种编程思想。接口作为实体抽象出来的一种表现形式,用于分离内部实现和外部沟通,最终达到内部变动而不影响外部与其他实现交互的目的。可以理解成,按照这种思想来设计编程的方式称为面向接口编程。

面向接口编程归属于面向对象编程。它是属于面向对象思想体系中的一部分,或者说它是面向对象编程体系中的思想精髓之一。

还是关于洗手的例子:

  • 对于手这个对象,可以规范出一个接口,每个人的手都可以实现这个接口。这个接口都包含基本的属性,如肤色、手指等;都包含基本的方法,如洗手、开启水龙头等。
  • 对于水龙头这个对象,可以规范出接口,每个不同的水龙头都可以实现这个接口。包含基本的属性,如材质、开关的方向等;包含基本的方法,如出水等

有了这两个接口,不管是谁、那个地方、那个国家的手或者水龙头,都可以实现上边两个接口,然后轻松完成洗手这个事件。

当然,以后如果科技发达了,不用水洗手了,直接用水龙头一照就可以了,那么我们就可以在水龙头接口里边,添加一个包含实现的方法(在 C# 8.0 之后可实现),这样也就不用担心已经实现了水龙头的类出错。

通过上边的例子知道,接口可以把某一类对象的统一属性和方法,声明在一起,然后实体类再来是现接口中的全部声明,然后在通过这个类实例化出具体的对象。这样就形成了高内聚低耦合、提高了可维护性,从而降低系统维护成本。

三、小小的总结

面向对象编程

适用于用户需求经常变化,性能要求不算最高的系统开发。

  • 易理解:采用面向对象思想设计开发,更符合人的思考方式,可读性高。
  • 易维护:面向对象有封装、继承、多态性的特性,即使需求有变动,需要维护的更多是局部模块,维护起来更加方便和更低成本。
  • 易扩展:面向对象有封装、继承、多态性的特性,在设计系统阶段可以设计出高内聚、低耦合的系统结构,使得系统更灵活、更容易扩展。
  • 易复用:也是同理,因为面向对象的三大特性,使得通用代码可以更简单的复用,提高开发效率。
  • 性能会比面向过程低,编程复杂度较高

面向过程编程

适用于性能要求较高的系统开发。

  • 简化了事件处理的过程,一步一步执行更加易于理解。
  • 性能比面向对象编程高,面向对象编程中类调用过程需要加载、实例化,资源消耗更大。对性能要求高的产品,比如单片机、嵌入式开发、 Linux/Unix 等,一般采用面向过程开发。
  • 没有面向对象编程易维护、易复用、易扩展

面向接口编程

  • 程序结构清晰,使用方便
  • 接口经过合理设计后,有利于程序设计的规范化,并可以并行开发,提高工作效率
  • 实现了程序的可插拔性,对于不同的需求切换不同的实现,降低了耦合度,随着系统复杂性的提高这个优势会越来越明显
  • 允许多重实现,弥补了继承的缺陷
  • 增加了设计的复杂度,不佳的接口的设计会对所有使用接口的层都有影响,并且并不是所有的程序的都需要使用接口,接口只有在系统的复杂性达到一定程度才能体现出它的优势,否则只是纯粹的增加工作量
  • 可能会降低代码的可复用性
  • 可能会降低程序的执行效率

参考:https://zhuanlan.zhihu.com/p/407548596  https://zhuanlan.zhihu.com/p/75265007  https://blog.csdn.net/wantken/article/details/31763669