python基础之面向对象02

---继承

  当我们定义完成某个类时,可以再定义一个新类,新类可以继承第一个类。新类被称为子类,而被继承的类称为父类/基类/超类。

  继承可以使子类使用父类中的方法,也可以在子类中新定义某个方法,或者在子类中覆盖父类的方法。

来看一个实例:

class animal(object):    #定义一个动物类
    def running(self):
        print(‘running....‘)
class dog(animal):       #定义一个狗类,且狗类继承动物类
    def wangwang(self):
        print(‘wang! wang!‘)

xiaohei=dog()
xiaohei.running()
xiaohei.wangwang()
#结果
running....
wang! wang!

  我们可以看到,在上面的例子中,dog类继承animal类后,就不需要再重新定义running方法,可以直接调用animal中的running方法。这就是继承的优点之一。
  如果我们在dog类中也定义一个running方法会怎样?

class animal(object):
    def running(self):
        print(‘running....‘)
class dog(animal):
    def wangwang(self):
        print(‘wang! wang!‘)
    def running(self):
        print(‘dog is running‘)
#结果
dog is running       #父类的方法被子类同名的方法覆盖
wang! wang!

  也就是,子类中的方法会覆盖父类中同名的方法!

---多继承

 所谓多继承就是指一个子类可以继承多个父类。大家可能会问:

  1 怎么样才能实现多继承?

  2 如果每个父类都有一个名称相同的方法,当子类调用该方法时最终调用的是哪一个?

1 首先来看第一个问题,怎么样才能实现多继承?

class animal(object):
    def running(self):
        print(‘running....‘)
class mammal(object):
    def grow(self):
        print(‘吃奶‘)
class dog(animal,mammal):     #<-----------在括号中加入父类名称,并以逗号分隔即可
    def wangwang(self):
        print(‘wang! wang!‘)
    def running(self):
        print(‘dog is running‘)

xiaohei=dog()
xiaohei.running()
xiaohei.wangwang()
xiaohei.grow()
#结果
dog is running
wang! wang!
吃奶

  注意:Python的类可以继承多个类,Java和C#中则只能继承一个类。

2 再来看第二个问题:如果每个父类都有一个名称相同的方法,当子类调用该方法时最终调用的是哪一个?或者说继承顺序是怎样的?

  在回答这个问题之前,我们需要先了解经典类和新式类。

什么是经典类什么是新式类?

class  class_name:  #经典类的定义方法
    pass

class  class_name(object):  #新式类的定义方法
    pass

  新式类较之经典类添加了很多功能,所以现在推荐用新式类。

网上有很多关于新式类和经典类的说明,很多都在说经典类基于深度优先,新式类基于广度优先。但我经过测试(python-3.5)发现其实不管是新式类还是经典类都是基于广度优先。

class CA():
    var = ‘a‘
class CB(CA):
    pass
class CC(CA):
    var = ‘c‘
class CD(CB, CC):
    pass
""" new-style class """
class NA(object):
    var = ‘a‘
class NB(NA):
    pass
class NC(NA):
    var = ‘c‘
class ND(NB, NC):
    pass
print(CD.var)
print(ND.var)
#结果
c
c

---方法

python中的方法包括普通方法/静态方法/类方法。但静态方法和类方法并不常用。

所有方法均属于类属性,也就是在内存中只有一份

  普通方法:只能由实例调用,最少有一个self参数

  静态方法:不需实例化就可以调用,没有默认参数

  类方法:不需实例化就可以调用。最少有一个cls参数

class test(object):

    def show1(self):
        print(‘普通方法‘)
    @staticmethod             #静态方法
    def show2():
        print(‘静态方法‘)
    @classmethod              #类方法
    def show3(cls):
        print(‘类方法‘)

#不实例化
test.show2()
test.show3()
print(‘------------分隔-------------‘)
#实例化
a=test()
a.show1()
a.show2()
a.show3()

#结果
静态方法
类方法
------------分隔-------------
普通方法
静态方法
类方法

---属性

之前我们讲过,在类中的某个变量前加上两个下划线,就可以将这个变量“隐藏”起来,使其外部不可见。

class atm00(object):
    def __init__(self,money):
        self.money=money
    def show_money(self):
        print(‘the atm has %s¥ ‘%self.money)

a=atm00(100)
a.show_money()
a.money=120
a.show_money()
#结果
the atm has 100¥
the atm has 120¥
#很明显,我们可以直接在外部给a.money赋值,这样虽然操作简单,但是我们无法验证用户输入的money是否合法

这时,我们可以这样修改:

class atm01(object):

    def __init__(self,money):
        self.__money=money
    def show_money(self):
        print(‘the atm has %s¥ ‘%self.__money)
    def set_money(self,money):                            #当修改money时,还可以检测用户输入的值是否合法
        if not isinstance(money,int):
            print("money‘s value must be interger")
        else:
            self.__money=money
a=atm01(100)
a.show_money()a.set_money(120

通过修改,我们让代码更健壮更安全,但是却没有之前在外部直接赋值时的便捷了。有没有一种方法,即可以在外部直接赋值,有可以检测用户输入值的合法性呢?这里我们就要用到属性了!

class atm01(object):
    def __init__(self,money_value):
        self.__money=money_value
    @property                            #第一种属性
    def money(self):
        return self.__money
    @money.setter              #第二种属性
    def money(self,money_value):
        if not isinstance(money_value,int):
            print("money‘s value must be interger")
        else:
            self.__money=money_value
    @money.deleter              #第三种属性
    def money(self):
        print(‘no money‘)

a=atm01(100)
print(a.money)
a.money=120
print(a.money)
del a.money
#结果
100
120
no money

上面的代码可能会看不懂,没关系,上面仅仅是用来说明属性的重要性,接下来我们来正式的讲解一下属性。

如何定义属性?

属性共有三种。

首先来看第一种属性:

class test(object):
  def step1(self):
        pass
  @property           #定义时,在普通方法的基础上添加 @property 装饰器,该方法就成为属性
    def step2(self):
        return ‘hello world‘
a=test()
print(a.step2)
#结果
hello world

  注意两点:

    1  属性中仅能包含一个self参数

    2  调用属性时,不需要加括号

第二种和第三种属性:

# ############### 定义 ###############
class Goods(object):

    @property
    def price(self):
        print ‘@property‘

    @price.setter
    def price(self, value):
        print ‘@price.setter‘

    @price.deleter
    def price(self):
        print ‘@price.deleter‘

# ############### 调用 ###############
obj = Goods()

obj.price          # 执行@property 修饰的 price 方法,并获取方法的返回值

obj.price = 123    # 执行@price.setter 修饰的 price 方法,并将  123 赋值给方法的参数

del obj.price      # 执行@price.deleter 修饰的 price 方法

总结一下,这三种属性作用分别为显示,修改,删除。

时间: 2024-10-22 15:50:48

python基础之面向对象02的相关文章

Day6 - Python基础6 面向对象编程

Python之路,Day6 - 面向对象学习 本节内容: 面向对象编程介绍 为什么要用面向对象进行开发? 面向对象的特性:封装.继承.多态 类.方法. 引子 你现在是一家游戏公司的开发人员,现在需要你开发一款叫做<人狗大战>的游戏,你就思考呀,人狗作战,那至少需要2个角色,一个是人, 一个是狗,且人和狗都有不同的技能,比如人拿棍打狗, 狗可以咬人,怎么描述这种不同的角色和他们的功能呢? 你搜罗了自己掌握的所有技能,写出了下面的代码来描述这两个角色 1 2 3 4 5 6 7 8 9 10 11

Python基础09 面向对象的进一步拓展

Python基础09 面向对象的进一步拓展 作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 我们熟悉了对象和类的基本概念.我们将进一步拓展,以便能实际运用对象和类. 调用类的其它信息 上一讲中提到,在定义方法时,必须有self这一参数.这个参数表示某个对象.对象拥有类的所有性质,那么我们可以通过self,调用类属性. class Human(object): laugh = 'hahahaha' def show_laugh(

Python基础08 面向对象的基本概念

Python基础 面向对象的基本概念 作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 谢谢逆水寒龙,topmad和Liqing纠错 Python使用类(class)和对象(object),进行面向对象(object-oriented programming,简称OOP)的编程. 面向对象的最主要目的是提高程序的重复使用性.我们这么早切入面向对象编程的原因是,Python的整个概念是基于对象的.了解OOP是进一步学习Python

Python基础之面向对象基本概念

面向过程和面向对象概念 过程和函数:过程类似于函数,只能执行,但是没有返回结果:函数不仅能执行,还能返回结果. 面向过程和面向对象 基本概念 面向过程-怎么做 把完成某一个需求的所有步骤从头到尾逐步实现: 根据开发需求,将某些功能独立的代码封装成一个又一个函数: 最后完成的代码,就是顺序的调用不同的函数. 特点 注重步骤和过程,不注重职责分工: 如果复杂需求,代码会变得很复杂: 开发复杂项目,没有固定的套路,开发难度很大. 面向对象-谁来做 相比较函数,面向对象是更大的封装,根据职责在一个对象中

python基础之面向对象高级编程

面向对象基本知识: 面向对象是一种编程方式,此编程方式的实现是基于对 类 和 对象 的使用 类 是一个模板,模板中包装了多个"函数"供使用(可以讲多函数中公用的变量封装到对象中) 对象,根据模板创建的实例(即:对象),实例用于调用被包装在类中的函数 面向对象三大特性:封装.继承和多态 本篇将详细介绍Python 类的成员.成员修饰符.类的特殊成员. 类的成员 类的成员可以分为三大类:字段.方法和属性 注:所有成员中,只有普通字段的内容保存对象中,即:根据此类创建了多少对象,在内存中就有

Python基础之面向对象(进阶篇)

面向对象是一种编程方式,此编程方式的实现是基于对 类 和 对象 的使用 类 是一个模板,模板中包装了多个“函数”供使用(可以讲多函数中公用的变量封装到对象中) 对象,根据模板创建的实例(即:对象),实例用于调用被包装在类中的函数 面向对象三大特性:封装.继承和多态 本篇将详细介绍Python 类的成员.成员修饰符.类的特殊成员. 类的成员 类的成员可以分为三大类:字段.方法和属性 注:所有成员中,只有普通字段的内容保存对象中,即:根据此类创建了多少对象,在内存中就有多少个普通字段.而其他的成员,

python3 速查参考- python基础 8 -&gt; 面向对象基础:类的创建与基础使用,类属性,property、类方法、静态方法、常用知识点概念(封装、继承等等见下一章)

基础概念 1.速查笔记: #-- 最普通的类 class C1(C2, C3): spam = 42 # 数据属性 def __init__(self, name): # 函数属性:构造函数 self.name = name def __del__(self): # 函数属性:析构函数 print("goodbey ", self.name) I1 = C1('bob') #-- Python的类没有基于参数的函数重载 class FirstClass: def test(self,

Python基础之面向对象2(封装)

一.封装定义: 二.作用 三.私有成员: 1.基本概念及作用 2.__slots__手段私有成员: 3.@property属性手段私有成员: 四.基础示例代码 1.用方法封装变量 """ 练习:用方法封装变量 """ class Enemy: def __init__(self,name,atk,speed,hp): self.set_name(name) self.set_atk(atk) self.set_atk_speed(speed) s

python基础_面向对象进阶

@property装饰器 之前我们讨论过Python中属性和方法访问权限的问题,虽然我们不建议将属性设置为私有的,但是如果直接将属性暴露给外界也是有问题的,比如我们没有办法检查赋给属性的值是否有效.我们之前的建议是将属性命名以单下划线开头,通过这种方式来暗示属性是受保护的,不建议外界直接访问,那么如果想访问属性可以通过属性的getter(访问器)和setter(修改器)方法进行对应的操作.如果要做到这点,就可以考虑使用@property包装器来包装getter和setter方法,使得对属性的访问