如何通俗易懂地举例说明“面向对象”和“面向过程”有什么区别?

作者:匿名用户
链接:https://www.zhihu.com/question/27468564/answer/101951302
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

楼主诸位说的都太复杂,我们应该从编程的发展史来谈面向对象的出现。

当软件还非常简单的时候,我们只需要面向过程编程:

定义函数
函数一
函数二
函数三
函数四

定义数据
数据一
数据二
数据三
数据四

最后
各种函数,数据的操作。

当软件发展起来后,我们的软件变得越来越大,代码量越来越多,复杂度远超Hello World的时候,我们的编写就有麻烦了:

函数和数据会定义得非常多,面临两个问题。

首先是命名冲突,英文单词也就那么几个,可能写着写着取名时就没合适的短词用了,为了避免冲突,只能把函数名取得越来越长。

然后是代码重复,比如你做一个计算器程序,你的函数就要确保处理的是合理的数据,这样最起码加减乘除四个函数里,你就都要写对参数进行检测的代码,写四遍或者复制粘贴四遍不会很烦,但多了你就痛苦了,而且因为这些检测代码是跟你的加减乘除函数的本意是无关的,却一定要写在那里,使代码变得不好阅读,意图模糊。

就算一个网络小说的作者,他每次写新章节时也不大可能直接打开包含着前面几百章文字的文档接着写。更正常的做法是新建一个文档,写新的一章,为的是减小复杂性,减少干扰。更何况代码那么复杂那么容易出错的东西。

随着软件业的发展,解决办法就要出来了。

代码重复,我们可以用函数里面调用函数的方法,比如把检测代码抽出来成一个独立函数,然后加减乘除四个函数运行时只要调用一下检测函数对参数进行检查就可以了。分布在四个函数里的重复代码变成了一个函数,是不是好维护多了。

命名冲突,我们就把这一堆函数们进行分类吧。

比如没有分类时候,我们取名只能取名:

检测
整数加
整数减
整数乘
整数除
复数加
复数减
复数乘
复数除
小数加
...

进行归类后

整数 {
   检测
   加
   减
   乘
   除
}
复数 {
   检测
   加
   减
   乘
   除
}
小数 {
   检测
   加
   减
   乘
   除
}
分数 {
   检测
   加
   减
   乘
   除
}

是不是一种叫做类的概念就呼之欲出了,这样我们打开一个整数类代码文件,里面就是简简单单的加减乘除四个函数,简单清晰而不会跟外面的其他加减乘除函数命名冲突。

当然,进行归类后,又有各种的问题和解决办法了,比如四个类中的检测也是应该提取出来的,所以简单的起因最终发展出什么继承衍生之类挺复杂的一套编程模式。然后学术界那帮人就又乱起什么高大上的名字了,所谓面向对象程序设计去祸害大学里那帮孩子。

就算未来出来一个什么新的面向XX编程,我们也不用多想为什么会出现,肯定是为了解决麻烦而已。

2016年5月23日更新:

上面进行归类后,代码其实还是不好维护的,然后我们就继续提取为:

数 {
    检测
    加
    减
    乘
    除
}
整数 {
    沿用上面数的设计
}
小数 {
    沿用上面数的设计
}

所谓继承,就是数这个类的整体设计,沿用给整数,分数小数这些类,作为他们的编写大纲去编写加减乘除这些函数的具体代码。根据整数,分数,小数各自的性质,做出各自的调整。

这时数这个类,如果你给它里面的加减乘除函数的写了一些很粗糙简单的代码,就叫做父类,基础类。子类们“继承”了父类(把代码进行了复杂化)。

如果没写,那这个类其实就只是个设计图,叫做抽象类。子类们“实现”了抽象类(把空空的设计变成了具体代码)。

模版是什么?像C++这种复杂成狗的语言是强类型的,就是给变量进行了类型区分的,比如整数类型,双整数类型。很明显这两种变量所能容纳的数据体积是不一样的,单个函数不能通吃多种类型的参数,我们就可能会面临下面两套代码并存的局面。

单整数类 {
    单整数加
    单整数减
    单整数乘
    单整数除
}
双整数类 {
    双整数加
    双整数减
    双整数乘
    双整数除
}

所以C艹跟其他强类型语言为我们提供了一个所谓模版功能:

<变量类型>整数 {
    <变量类型>加
    <变量类型>减
    <变量类型>乘
    <变量类型>除
}

整数类等于把变量类型设置为整数,套上模版双整数类等于把变量类型设置为双整数,套上模版

这样就写了一份代码,得到了两份类的代码。

当然,弱类型的编程语言,比如JavaScript或者PHP是没有这种烦恼的,因为变量没有类型之分。但变量类型有时候还是很重要的,弱类型语言里就会出现类似数加字符串这种运算,可能并不是程序员的预期和本意,所以比起强类型性语言而言经常会出现很多无聊的BUG。

再更新:

上面发展出了父类之后,我们发现编程还是有问题的,小数类:

小数类 {
    加
    减
    乘
    除
}

如果我们需要一个能自动实现结果四舍五入的小数计算类,同时又需要一个不需要的,怎么办呢,难道要写两个类吗?不要。

所以做出了“实例”或者“对象”这一东西,首先把类改成:

小数类 {
    标识变量:是否四舍五入
    标识变量:是否限定小数点后位数
    构造函数(设置上面的标识)
    加(会根据上面两个标识变量输出不同结果)
    减(会根据上面两个标识变量输出不同结果)
    乘(会根据上面两个标识变量输出不同结果)
    除(会根据上面两个标识变量输出不同结果)
}

这样,我们就写一个类,但是通过构造函数,把一份代码,构造出了行为稍微有点不同的两个实例供我们使用,这时候名词来了,不能进行实例化微调化的类,叫做静态类,函数们的行为是固定的。不能实例化的类,其实只是函数们的一个集合归纳,只是对函数进行了整理,功能的强大和编码的自由灵活度是不够的。

能够进行实例化,变化出各种行为各自不大一样的实例的类,我们一般就把它们叫做类了,因为最常见。

程序员们也就能保持代码简单的同时而又可以很方便进行代码行为微调了。

面向对象是一种编程思想和方法,它把现实世界中的事物抽象成程序中的对象。我们可以将对象想象成真实世界中的物体,比如人、动物、汽车等等。每个对象都有自己的属性和行为。 属性是对象的特征,用来描述对象的状态。比如,一个人有姓名、年龄、性别等属性,一辆汽车有品牌、颜色、价格等属性。 行为是对象能够做的事情,表达对象的功能。比如,一个人可以吃饭、睡觉、跑步等行为,一辆汽车可以加速、刹车、转弯等行为。 面向对象编程将问题分解成多个对象,通过对象之间的交互来解决问题。对象可以通过封装、继承和多态这样的特性来组织和管理。 封装是指把对象的属性和行为封装在一起,对外部隐藏对象的内部实现细节,只暴露出一些公共的方法供外界使用。这样可以保护对象的数据安全。 继承是一种创建新的对象的方式,通过继承可以让一个对象获得另一个对象的属性和行为。父类中定义的属性和方法可以在子类中重复使用,减少代码的重复编写。 多态是同一个行为具有不同的表现形式,可以让一个方法在不同的对象上有不同的表现。通过多态可以提高代码的灵活性和可扩展性,增加程序的可维护性。 面向对象编程有助于提高开发效率,使代码结构更清晰,易于理解和维护。通过分解问题成多个对象,每个对象只关注自己的功能,降低了代码的复杂性。同时,面向对象编程还能够提高代码的重用性,减少代码量,加快开发速度。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值