1、结构化、面向对象程序设计差别、类基本概念
1、面向对象程序设计与结构化程序设计的优缺点对比
(1)结构化程序(C程序为例)的特点
- 程序 = 数据结构 + 算法
- 程序由全局变量以及众多相互调用的函数组成, 算法以函数的形式实现,用于对数据结构进行操作。
(2)结构化程序设计缺点
① 结构化程序设计中,函数和其所操作的数据结构,没有直观的联系。随着程序规模的增加,程序逐渐难以理解,很难一下子看出来:
- 某个数据结构到底有哪些函数可以对它进行操作?
- 某个函数到底是用来操作哪些数据结构的?
- 任何两个函数之间存在怎样的调用关系?
②结构化程序设计没有“封装”和“隐藏”的概念。
③要访问某个数据结构中的某个变量,就可以直接访问,那么当该变量的定义有改动的时候,就要把所有访问该变量的语句找出来修改,十分不利于程序的维护、扩充。
④ 难以查错,当某个数据结构的值不正确时,难以找出到底是那个函数导致的。
⑤重用:在编写某个程序时,发现其需要的某项功能,在现有的某个程序里已经有了相同或类似的实现,那么自然希望能够将那部分代码抽取出来,在新程序中使用。
⑥在结构化程序设计中,随着程序规模的增大,由于程序大量函数、变量之间的关系错综复杂,要抽取这部分代码,会变得十分困难。
软件业的目标是更快、更正确、更经济地建立软件。总之,结构化的程序,在规模庞大时,会变得难以理解,难以扩充(增加新功能),难以查错,难以重用。违背了软件设计的目标。
(3)面向对象程序设计的特点
- 面向对象的程序设计方法,能够较好解决上述问题。
- 面向对象的程序 = 类 + 类 + …+ 类
- 设计程序的过程,就是设计类的过程。
(4)面向对象的程序设计方法:
- 将某类客观事物共同特点(属性)归纳出来,形成一个数据结构(可以用多个变量描述事物的属性);
- 将这类事物所能进行的行为也归纳出来,形成一个个函数,这些函数可以用来操作数据结构(这一步叫“ 抽象”)。
然后,通过某种语法形式,将数据结构和操作该数据结构的函数“捆绑”在一起,形成一个“ 类”,从而使得数据结构和操作该数据结构的算法呈现出显而易见的紧密关系,这就是“封装” 。面向对象的程序设计具有“抽象”,“封装”“继承”“多态”四个基本特点。
2、使用成员函数与成员变量的三种方式
- 对象名.成员名
- 指针->成员名
- 引用名.成员名
3、对象的内存分匹配
- 和结构变量一样,对象所占用的内存空间的大小,等于所有成员变量的大小之和。
- 每个对象各有自己的存储空间。一个对象的某个成员变量被改变了,不会影响到另一个对象。
4、对象间运算
和结构变量一样,对象之间可以用 “=”进行赋值,但是不能用 “ ==”,“ !=”,“ >”,“ <”“ >=”“ <=”进行比较,除非这些运算符经过了“重载”。