面向对象(Object Oriented,OO)是软件开发方法。面向对象的概念和应用已超越了程序设计和软件开发,扩展到如数据库系统、交互式界面、应用结构、应用平台,分布式系统,网络管理结构、CAD技术、人工智能领域。面向对象是一种对现实世界理解和抽象的方法,是计算机编程技术发展到一定阶段后的产物。
--百度百科
起初面向对象是专指在程序设计中采用封装,继承,多态等设计方法。
在C#学习的基础阶段,我们只需要知道就是指通过对象来调用方法就可以了,过于执着于概念反而念头不通达。想要深入的理解,生活上多思考,开发中多敲代码来体会,很难通过别人的几句话来理解清晰。
——以下是我接触过并对我比较有触动的解释和建议:
1>想要深入了解面向对象,可以读一下《Java编程思想》,虽然例子用的是Java语言,但是面向对象的思想和C#是相通的,再者说,学习C#或多或少都要接触Java。
2>这个就比较豪放了,面向对象就是个XX(略过,贬义词),你只需要知道代码怎么敲就可以了。我的理解就是,这么多年都没有能统一出一个精准易懂的描述,我们不必一开始就去做那个第一个把它描述出来的人,多用,多做,多体会,如是而已。
3>这条是刚刚参加工作时,总监做的简单培训,对于开发来说,实用:
简单介绍面向对象的设计原则(这是我听过最简单粗暴的设计原则讲解):
1,开闭原则-->对扩展开发,对修改关闭-->写代码时候要注意
2,里氏替换原则-->适用于基类的一定适用于其子类-->继承
3,依赖倒转原则-->尽量依赖于抽象不要依赖于具体-->接口
4,接口隔离-->使用多个专门的接口比使用单一的总接口要好
5,合成聚合复用原则-->尽量少用继承--防止层次过深,难以控制,不要有三级以上的继承 合成聚合实现继承两个类,这样来完成
多继承。——在多继承或继承层次比较深的情况下适用这个法则
6,迪米特法则--为什么它是法则而不是原则
-->一个对象因对其他的对象尽可能的少了解——内部实现的方法不对外部公开,通过参数的形式交给外部调用,但是
实际上,参数一多就难以控制,尽量少用函数的参数(3个以内最佳),谨慎的公开一些属性。类内高内聚,类外低耦合。
当然这些话不依托于代码都比较枯燥,但是配上特定代码又容易误导,还是在自己开发的时候多带着这些问题思考比较好。
然后要了解一个事物,除了从它本身来了解,对比也是个不错的切入方式。
-->这里引用百度知道的一组问答:
面向对象和面向过程的区别?
面向过程就是分析出解决问题所需要的步骤,然后用函数把这些步骤一步一步实现,使用的时候一个一个依次调用就可以了。
面向对象是把构成问题事务分解成各个对象,建立对象的目的不是为了完成一个步骤,而是为了描叙某个事物在整个解决问题的步骤中的行为。
例如:
五子棋,
面向过程的设计思路就是首先分析问题的步骤:
1、开始游戏,2、黑子先走,3、绘制画面,4、判断输赢,5、轮到白子,6、绘制画面,7、判断输赢,8、返回步骤2,9、输出最后结果。
把上面每个步骤用分别的函数来实现,问题就解决了。
而面向对象的设计则是从另外的思路来解决问题。
整个五子棋可以分为 1、黑白双方,这两方的行为是一模一样的,2、棋盘系统,负责绘制画面,3、规则系统,负责判定诸如犯规、输赢等。第一类对象(玩家对象)负责接受用户输入,并告知第二类对象(棋盘对象)棋子布局的变化,棋盘对象接收到了棋子的i变化就要负责在屏幕上面显示出这种变化,同时利用第三类对象(规则系统)来对棋局进行判定。
可以明显地看出,面向对象是以功能来划分问题,而不是步骤。同样是绘制棋局,这样的行为在面向过程的设计中分散在了总多步骤中,很可能出现不同的绘制版本,因为通常设计人员会考虑到实际情况进行各种各样的简化。而面向对象的设计中,绘图只可能在棋盘对象中出现,从而保证了绘图的统一。
功能上的统一保证了面向对象设计的可扩展性。
比如我要加入悔棋的功能,如果要改动面向过程的设计,那么从输入到判断到显示这一连串的步骤都要改动,甚至步骤之间的循序都要进行大规模调整。如果是面向对象的话,只用改动棋盘对象就行了,棋盘系统保存了黑白双方的棋谱,简单回溯就可以了,而显示和规则判断则不用顾及,同时整个对对象功能的调用顺序都没有变化,改动只是局部的。
再比如我要把这个五子棋游戏改为围棋游戏,如果你是面向过程设计,那么五子棋的规则就分布在了你的程序的每一个角落,要改动还不如重写。但是如果你当初就是面向对象的设计,那么你只用改动规则对象就可以了,五子棋和围棋的区别不就是规则吗?(当然棋盘大小好像也不一样,但是你会觉得这是一个难题吗?直接在棋盘对象中进行一番小改动就可以了。)而下棋的大致步骤从面向对象的角度来看没有任何变化。
当然,要达到改动只是局部的需要设计的人有足够的经验,使用对象不能保证你的程序就是面向对象,初学者或者很蹩脚的程序员很可能以面向对象之虚而行面向过程之实,这样设计出来的所谓面向对象的程序很难有良好的可移植性和可扩展性。