Heim >Backend-Entwicklung >Python-Tutorial >Python中的面向对象编程详解(下)

Python中的面向对象编程详解(下)

WBOY
WBOYOriginal
2016-06-10 15:15:29990Durchsuche

继承

继承描述了基类的属性如何“遗传”给派生类。一个子类可以继承它的基类的任何属性,不管是数据属性还是方法。
创建子类的语法看起来与普通(新式)类没有区别,一个类名,后跟一个或多个需要从其中派生的父类:

复制代码 代码如下:

class SubClassName (ParentClass1[, ParentClass2, ...]):
    'optional class documentation string'
    class_suite

实例
复制代码 代码如下:

class Parent(object): # define parent class 定义父类
    def parentMethod(self):
    print 'calling parent method'

class Child(Parent): # define child class 定义子类
    def childMethod(self):
    print 'calling child method'


继承与覆盖

继承

不同于Java,python的子类继承父类后,会把父类的所有的方法,包括构造器init()也继承下来.

复制代码 代码如下:

class Parent():
    def __init__(self):
        print "init Parent class instance"

    def func(self):
        print "call parent func"

class Child(Parent):
    def __init__(self):
        print "init Child class instance"

child = Child()
child.func()


输出
复制代码 代码如下:

init Child class instance
call parent func

super关键字

super 是用来解决多重继承问题的,直接用类名调用父类方法在使用单继承的时候没问题,但是如果使用多继承,会涉及到查找顺序(MRO)、重复调用(钻石继承)等种种问题。语法如下

复制代码 代码如下:

super(type[, obj])

示例
复制代码 代码如下:

class C(B):
    def method(self, arg):
        super(C, self).method(arg)

注意

super继承只能用于新式类,用于经典类时就会报错。
新式类:必须有继承的类,如果没什么想继承的,那就继承object
经典类:没有父类,如果此时调用super就会出现错误:『super() argument 1 must be type, not classobj』
实例

复制代码 代码如下:

class Parent(object):
    def __init__(self):
        self.phone = '123456'
        self.address = 'abcd'

class Child(Parent):
    def __init__(self):
        super(Child, self).__init__()
        self.data = 100

def main():
    child = Child()
    print "phone is: ", child.phone
    print "address is: ", child.address
    print "data is: ", child.data

if __name__ == '__main__':
    main()


输出
复制代码 代码如下:

phone is:  123456
address is:  abcd
data is:  100

重写

子类只要重新定义一个与父类的方法同名的方法,就可以重写覆盖父类的方法. 子类只要把上例父类的func(self)重写就行了.

复制代码 代码如下:

class Parent():
def __init__(self):
print "init Parent class instance"
def func(self):
print "call parent func"
class Child(Parent):
def __init__(self):
print "init Child class instance"

child = Child()
child.func()


输出
复制代码 代码如下:

init Child class instance
call Child func

多重继承

同 C++一样,Python 允许子类继承多个基类。但一般不推荐用多重继承.语法如下:

复制代码 代码如下:

class Father():
    def __init__(self):
        print "init Father instance"

class Mother():
    def __init__(self):
        print "init Mother instance"

class Child(Father, Mother):
    pass


类、实例和其他对象的内建函数

issubclass()

布尔函数判断一个类是另一个类的子类或子孙类。它有如下语法:

复制代码 代码如下:

issubclass(sub, sup)

isinstance()

布尔函数在判定一个对象是否是另一个给定类的实例时,非常有用。它有如下语法:

复制代码 代码如下:

isinstance(obj1, obj2)

attr()系列函数

●hasattr()
它的目的就是为了决定一个对象是否有一个特定的属性,一般用于访问某属性前先作一下检查。
●getattr()和setattr()
●getattr()和 setattr()函数相应地取得和赋值给对象的属性,

●delattr()
删除特定的属性

实例

复制代码 代码如下:

class Child(Parent):
    def __init__(self):
        self.data = 100

child = Child()
print "has data attr?", hasattr(child, 'data')

print "delete attr"
delattr(child, 'data')

print "has data attr?", hasattr(child, 'data')

print "set data attr to 200"
setattr(child, 'data', 200)
print "data attr is: ", getattr(child, 'data')


输出
复制代码 代码如下:

has data attr? True
delete attr
has data attr? False
set data attr to 200
data attr is:  200

私有化

Python没有像Java那样实现真正的封装,只是用双划线和单划线实现私有化.

●双划线
防止外部访问.如在func前加双划线,可以防止包括子类的实例的访问.

复制代码 代码如下:

    def __func(self):
        print "call"

●单划线
防止模块的属性用“from mymodule import *”来加载。
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn