365bet体育在线平台[python] 在 python二和3中有关类承继的 super方法简要表明

上边举3个例证,一样的代码应用 python2 和
python叁 写的,大家瞩目两段程序中黄褐加粗的一些:

下边举3个事例,同样的代码应用 python贰和
python三写的,我们只顾两段程序中革命加粗的一对:

@(python)

python 同时援助面向对象编制程序和函数式编程的语言
python面向对象的主旨围绕 类实例 多个核心。
面向对象三大特征:封装继承多态

python二的类承接使用super方法:

python二的类承继使用super方法:

super(type, obj)

子类中定义了同父类同名的函数后,须要出示调用父类函数时,能够透过
super,也得以一贯通过父类名,建议采纳super,比如在初叶化函数中调用父类开端化方法,特别在多种承继的图景下
探望例子:

#!/usr/bin/env python
# coding=utf-8

class A:
    def __init__(self):
        print("Enter A")
        super(A, self).__init__()
        print("Leave A")

class B:
    def __init__(self):
        print("Enter B")
        #super(B, self).__init__()
        print("Leave B")

class CA(A):
    def __init__(self):
        print("Enter CA")
        super(CA,self).__init__()
        print("Leave CA")


class CAA(CA, A):
    def __init__(self):
        print("Enter CAA")
        super(CAA,self).__init__()
        print("Leave CAA")

class CB(B):
    def __init__(self):
        print("Enter CB")
        B.__init__(self)
        print("Leave CB")


class CBB(CB, B):
    def __init__(self):
        print("Enter CBB")
        CB.__init__(self)
        B.__init__(self)
        print("Leave CBB")


if __name__ == "__main__":
    print("- New Object CAA")
    caa = CAA()
    print("- New Object CBB")
    cbb = CBB()

上述列子中,两组类关系:
CAA->CA->A 选用 super 调用父类函数
CBB->CB->B 直接通过父类名调用其行数

对待运维结果

lcd@ubuntu:~/learn/python$ python3 supper_class.py 
- New Object CAA
Enter CAA
Enter CA
Enter A
Leave A
Leave CA
Leave CAA
- New Object CBB
Enter CBB
Enter CB
Enter B   
Leave B
Leave CB
Enter B   -->重复调用了
Leave B
Leave CBB

可以观察,使用super, python
不止保险后续时按顺序调用父类初步化,而且保障每1个类不被再次调用。

概念

一.目的:类的实例。对象具备二日性状:状态与表现。
二.类:用来描述具备同等的属性和措施的对象的汇合,类的整合=方法+行为
三.虚无:对具体世界难点和实体的真相表现,行为和特点建立模型,建立一个有关的子集,能够用于描述程序结构,从而实现那种模型。
四.封装:对质量和艺术的载体类,只可以通过其提供的接口(方法)来走访,而把落实细节隐藏起来.python的类属性都以当众的。
伍.承继:描述了子类属性从祖先类承袭那样一种艺术。
陆.多态:同一新闻能够依据发送对象的不等而选择多种差异的表现格局。

 1 #-*-  coding:utf-8 -*-
 2 '''
 3 Created on 2018年8月27日
 4 
 5 @author: anyd
 6 '''
 7 import random as r
 8 
 9 class Fish(object):
10     def __init__(self):
11         self.x = r.randint(0, 10)
12         self.y = r.randint(0, 10)
13             
14     def move(self):
15         #这里主要演示类的继承机制,就不考虑检查场景边界和移动方向的问题
16         #假设所有鱼都是一路向西游
17         self.x -= 1
18         print "我的位置是:", self.x, self.y
19 
20 class Goldfish(Fish):
21     pass
22 
23 class Carp(Fish):
24     pass
25 
26 class Salmon(Fish):
27     pass
28 
29 #上边几个都是食物,食物不需要有个性,所以直接继承Fish类的全部属性和方法即可
30 #下边定义鲨鱼类,这个是吃货,除了继承Fish类的属性和方法,还要添加一个吃的方法
31 
32 class Shark(Fish):
33     def __init__(self):
34         super(Shark,self).__init__()       
35         self.hungry = True
36 
37     def eat(self):
38         if self.hungry:
39             print "吃货的梦想就是天天有的吃^_^"
40             self.hungry = False
41         else:
42             print "太撑了,吃不下了!"
43             
44 aa = Shark()
45 aa.move()
 1 #-*-  coding:utf-8 -*- 2 ''' 3 Created on 2018年8月27日 4  5 @author: anyd 6 ''' 7 import random as r 8  9 class Fish:10     def __init__:11         self.x = r.randint(0, 10)12         self.y = r.randint(0, 10)13             14     def move:15         #这里主要演示类的继承机制,就不考虑检查场景边界和移动方向的问题16         #假设所有鱼都是一路向西游17         self.x -= 118         print "我的位置是:", self.x, self.y19 20 class Goldfish:21     pass22 23 class Carp:24     pass25 26 class Salmon:27     pass28 29 #上边几个都是食物,食物不需要有个性,所以直接继承Fish类的全部属性和方法即可30 #下边定义鲨鱼类,这个是吃货,除了继承Fish类的属性和方法,还要添加一个吃的方法31 32 class Shark:33     def __init__:34         super(Shark,self).__init__()       35         self.hungry = True36 37     def eat:38         if self.hungry:39             print "吃货的梦想就是天天有的吃^_^"40             self.hungry = False41         else:42             print "太撑了,吃不下了!"43             44 aa = Shark()45 aa.move()

classsmethod

python 有两种艺术定义类方法:
如上边例子类 A 定义的七个方法,

  • 健康办法定义了 foo,同对象实例绑定,通过对象调用的时候,会由此隐式
    self 参数字传送递类对象实例子;假诺直接通过类调用,要求浮现传递类实例;
  • @classmethod 形式定义了 class_foo
    方法,同类绑定,能够直接通过类名能够一向调用,调用时经过 cls
    隐式参数字传送递类对象。
  • @staticmethod
    格局定义的措施和1般函数同样,未有绑定对象,没有传递隐式参,能够透过类实例大概类调用。(属于类的函数,但是不需求访问类,通过两次三番子类覆盖,更加好地组织代码)

#!/usr/bin/env python
# coding=utf-8
# by orientlu

class A(object):
    def __init__(self):
        print("A init")
        super().__init__()

    def foo(self, x):
        '''绑定对象'''
        print("A exec foo (%s, %d)" %(self, x))

    @classmethod
    def class_foo(cls, x):
        '''绑定类'''
        print("exec class_foo (%s, %d)" %(cls, x))

    @staticmethod
    def static_foo(x):
        '''没有绑定类,对象'''
        print("exec static_foo (%d)" %(x))

class B(object):
    def foo(self, x):
        '''绑定对象'''
        print("exec foo (%s, %d)" %(self, x))

    @classmethod
    def test_class_foo(cls, x):
        '''绑定类'''
        print("exec test_class_foo -2- (%s, %d)" %(cls, x))

    def test_class_foo(self, x):
        '''后面方法覆盖前面的同名方法'''
        print("exec test_class_foo -1- (%s, %d)" %(self, x))


class AA(A):
    def __init__(self):
        print("AA Int")

    def foo(self, x):
        '''覆盖了父类函数'''
        print("AA exec foo (%s, %d)" %(self, x))


class C(AA):
    def __init__(self):
        '''子类定义了方法覆盖了父类,通过super调用到父类函数'''
        super().__init__()
        print("C init")

    def c_fun1(self):
        '''子类没有定义的函数,直接调用父类函数'''
        self.foo(1)

if __name__ == "__main__":

    print("***********************************")
    print("-------")
    a = A()
    a.foo(1)
    a.class_foo(1)
    a.static_foo(1)

    print("-------")
    A.foo(a, 1)
    A.class_foo(1)
    A.static_foo(1)

    print("***********************************")
    b = B()
    b.test_class_foo(1)
    # 以下调用出错,因为classmethod被后面的函数所覆盖了
    #B.test_class_foo(1)
    # 实际存在是后面定义的函数
    B.test_class_foo(b, 1)

    print("***********************************")
    c = C()
    c.c_fun1()

上述代码在 python三 环境下运作的输出 :

***********************************
-------
A init
A exec foo (<__main__.A object at 0x7f6af4c36ac8>, 1)
exec class_foo (<class '__main__.A'>, 1)
exec static_foo (1)
-------
A exec foo (<__main__.A object at 0x7f6af4c36ac8>, 1)
exec class_foo (<class '__main__.A'>, 1)
exec static_foo (1)
***********************************
exec test_class_foo -1- (<__main__.B object at 0x7f6af4c36b38>, 1)
exec test_class_foo -1- (<__main__.B object at 0x7f6af4c36b38>, 1)
***********************************
AA Int
C init
AA exec foo (<__main__.C object at 0x7f6af4c36b70>, 1)
创建类

python 类是选取class关键词来创建,即重点词+类名

class ClassName():
    class_suit 
  • class_suit(类实体由类成员、方法、数据属性组成)
  • 类中的函数第三个参数必须是self,
  • 类分为特出类和新式类(要是当前类也许父类承接了object类,那么该类正是新式类,不然正是优秀类。现在渐次推荐用新型类写)
![](https://upload-images.jianshu.io/upload_images/994436-2e4347e91097c500.png)

QQ20170709-223954@2x.png

出口如下:

出口如下:

类的成员、成员修饰符、类的特别成员

365bet体育在线平台 1

Paste_Image.png

class Province:
    country = '中国'                     # 静态字段
    def __init__(self, name):
        self.name = name                 # 普通字段

obj = Province('河北省')                 # 直接访问普通字段
print obj.name
Province.country                        # 直接访问静态字段

365bet体育在线平台 2

Paste_Image.png

由上海体育地方然而:
静态字段在内部存储器中只保留壹份
常见字段在种种对象中都要保留一份
动用场景:
通过类创设对象时,倘诺各个对象都具备同样的字段,那么就使用静态字段

格局:普通方法、静态方法和类措施,三种艺术在内部存储器中都名下于类,不相同在于调用格局差异。

class E():
    i=1
    def run(self):
         E.i +=1
         print('{0} is run ordinary method'.format(E.i))
    @staticmethod
    def eat():
        E.i +=1
        print('{0} is eat static method'.format(E.i))
    @classmethod
    def fool(cls):
        E.i +=1
        print('{0} is fool class method '.format(E.i))

e = E()
e.run()
E.eat()
E.fool()

输出

2 is run ordinary method
3 is eat static method
4 is fool class method 

属性:至极3个bean里面包车型客车办法,做相比好的包裹1层,创设属性有2中方法,1种是修饰器,壹种是静态字段,装饰器格局针对卓绝类和新星类又有所分裂,上面例子针对新式类(图中-明天艺术开创
改为 静态方式创立)

365bet体育在线平台 3

Paste_Image.png

发表评论

电子邮件地址不会被公开。 必填项已用*标注