python面向对象和面向编程的区别
1.面向过程就是分析出解决问题所需要的步骤,然后用函数把这些步骤一步一步实现,使用的时候一个一个依次调用就可以了。
2.面向对象是把构成问题事务分解成各个对象,建立对象的目的不是为了完成一个步骤,而是为了描叙某个事物在整个解决的步骤中的行为。
举例子
拿生活中的实例来理解面向过程和面向对象,例如五子棋,面向过程的设计思想就是首先分析问题的步骤:1、开始游戏,2、黑子先走,3、绘制画画,4、判断输赢,5、轮到白子,6、绘制画面,7、判断输赢,8、返回步骤,9、输出最后结果。把上面每个步骤用不同的方法来实现。
如果是面向对象的设计思想来解决问题。面向对象的设计则是从另外的思路来解决问题。整个五子棋可以分为:1、黑白双方,这两方的行为是一样的,2、棋盘系统,负责绘制画面,3、规则系统,负责判定诸如规范输赢、第一类对象(玩家对象)负责接受用户输入,并告知第二类对象(棋盘对象)棋子布局的变化,棋盘对象接收到了棋子的变化就要负责在屏幕上面显示出这种变化,同时利用第三类对象(规则系统)来对棋局进行判定。
面向对象是以功能来划分问题,而不是步骤。
面向过程与面向对象的优缺点
面向过程
优点:性能比面向对象高,因为类调用时需要实例化,开销比较大,比较消耗资源,比如单片机、嵌入式开发、Linux/Unix等一般采用面向过程开发,性能是最重要的因素。
缺点:没有面向对象易维护、易复用、易扩展
面向对象
优点:易维护、易复用、易扩展,由于面向对象有封装、继承、多态性的特性,可以设计出低耦合的系统,使系统更加灵活、更加易于维护
缺点:性能比面向过程低
类和对象的概念
类即类别、种类,是面向对象设计最重要的概念,对象是特征与技能的结合体,而类则是一系列对象相似的特征与技能的结合体
在程序中,务必保证:先定义(类),后使用类(用来产生对象)
类属性和实例属性的区别
注意:属性查找,类有两种属性,分别为数据属性和函数属性
1.类的数据属性是所有对象共享的,id都一样
2.类的函数数据是绑定给对象用的,称为绑定到对象的方法,内存地址都不一样(
类中定义的函数(没有被任何装饰器装饰的),其实主要是给对象使用的,而且是绑定到对象的,虽然所有对象指向的都是相同的功能,但是绑定到不同的对象就是不同的绑定方法
总结
实例属性属于各个实例所有,互不干扰;
类属性属于类所有,所有实例共享一个属性;
不要对实例属性和类属性使用相同的名字,否则将产生难以发现的错误
类属性可以细分为一下三种类型
1.类体中、所有函数,此范围定义的变量,称为类属性和类变量;
2.类体中,所有函数内部:以"self.变量名"的方式定义的变量,称为实例属性或实例变量
3.类体中,所有函数内部:以"变量名=变量值"的方式定义的变量,称为局部变量
class student:
school="IT"
def age(self,student_age)
student_age=student_age
student.school
ming=student----->"IT"
ming.school----->"IT"
ming.student_age----->会报错(需要先调用这个方法先)
ming.age(1)
ming.student_age--->1
注意点
- 类变量的特点是
所有类的实例化对象都同时共享类变量,也就是说,类变量在所有实例化对象中是作为公用资源存在的。类方法的调用方式有2中,既可以使用类名直接调用,也可以使用类的实例化对象调用
因为类变量为所有实例化对象共有,通过类名修改类变量的值,会影响所有的实例化对象。通过类对象是无法修改类变量的,通过类对象对类变量赋值,其本质将不再是修改变量的值,而是在给对象定义新的实例变量
- 实例变量
在任意类方法内部,以"self.变量名"的方式定义的变量,其特点是只作用于调用方法的对象。另外实例变量只能通过对象访问,无法通过类名访问
定义局部变量是为了所在类方法功能的实现,局部变量只能用于所有函数中,函数执行完成后,局部变量也会被销毁。
查看类是否有继承、类有哪些方法和属性、继承寻找的顺序
查看类有哪些方法和属性:class.dict
查看类是否有继承:class.bases
查看类继承寻找的顺序:class.mro
(注意:只有新式才能有这个属性可以查看线性列表,经典类没有这个属性)