python面向对象编程

一、概述

面向对象编程——Object Oriented Programming,简称OOP,是一种程序设计思想。OOP把对象作为程序的基本单元,一个对象包含了数据和操作数据的函数。

面向对象的程序设计把计算机程序视为一组对象的集合,而每个对象都可以接收其他对象发过来的消息,并处理这些消息,计算机程序的执行就是一系列消息在各个对象之间传递。

在Python中,所有数据类型都可以视为对象,当然也可以自定义对象。自定义的对象数据类型就是面向对象中的类(Class)的概念。

数据封装、继承和多态是面向对象的三大特点。

二、类

class Student(object):

    def __init__(self, name, score):
        self.name = name ##实例属性
        self.score = score
        number = 0 ## 类属性

    def print_score(self):
        print('%s: %s' % (self.name, self.score))

在Python中,定义类是通过class关键字。class后面紧接着是类名,即Student,类名通常是大写开头的单词,紧接着是(object),表示该类是从哪个类继承下来的。

2.1 构造函数

通过定义一个特殊的__init__方法,在创建实例的时候,就把name,score等属性绑上去。

注意到__init__方法的第一个参数永远是self,表示创建的实例本身,因此,在__init__方法内部,就可以把各种属性绑定到self,因为self就指向创建的实例本身。

有了__init__方法,在创建实例的时候,就不能传入空的参数了,必须传入与__init__方法匹配的参数,但self不需要传。

和普通的函数相比,在类中定义的函数只有一点不同,就是第一个参数永远是实例变量self,并且调用时,不用传递该参数。

注:和静态语言不同,Python允许对实例变量绑定任何数据,也就是说,对于两个实例变量,虽然它们都是同一个类的不同实例,但拥有的变量名称都可能不同。

>>> bart = Student('Bart Simpson', 59)
>>> lisa = Student('Lisa Simpson', 87)
>>> bart.age = 8
>>> bart.age
8
>>> lisa.age
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
AttributeError: 'Student' object has no attribute 'age'

2.2 实例化

创建类实例是通过类名+()实现的:

bart = Student()
>>> class Student():
...     pass
...
>>> bart = Student()
>>> bart
<__main__.Student object at 0x7fd466495c10>

2.3 数据封装

要让内部属性不被外部访问,可以把属性的名称前加上两个下划线(__)。在Python中,实例的变量名如果以两个下划线(__)开头,就变成了一个私有变量(private),只有内部可以访问,外部不能访问。

在Python中,变量名类似__xxx__的,也就是以双下划线开头,并且以双下划线结尾的,是特殊变量,特殊变量是可以直接访问的,不是private变量,所以,不能用__name__、__score__这样的变量名。

有些时候,你会看到以一个下划线开头的实例变量名,比如_name,这样的实例变量外部是可以访问的,但是,按照约定俗成的规定,当你看到这样的变量时,意思就是,“虽然我可以被访问,但是,请把我视为私有变量,不要随意访问”。

由于Python是动态语言,根据类创建的实例可以任意绑定属性。给实例绑定属性的方法是通过实例变量,或者通过self变量。

2.4 类属性

直接在class中定义属性,这种属性是类属性,归类所有,但类的所有实例都可以访问到。

在编写程序的时候,千万不要对实例属性和类属性使用相同的名字,因为相同名称的实例属性将屏蔽掉类属性,但是当你删除实例属性后,再使用相同的名称,访问到的将是类属性。

实例属性属于各个实例所有,互不干扰;类属性属于类所有,所有实例共享一个属性。

三、扩展

1、super()

super()返回父类的代理对象,能调用父类的方法,不仅仅是__init__()。

继承时,用 super()调用父类方法​,在 __init__中必须调用​ super().init()或传递参数 来初始化父类。

class Parent:
    def __init__(self):
        self.value = 10

class Child(Parent):
    def __init__(self):
        super().__init__()  # 初始化父类的属性
        self.extra = 20

c = Child()
print(c.value)  # 10 ✅
super().method(args)  # 按照MRO调用
super(parent, self).method(args)   #指定具体类

参考:

1、面向对象编程 - 廖雪峰

posted @ 2017-02-05 18:47  yuxi_o  阅读(703)  评论(0)    收藏  举报