zoukankan      html  css  js  c++  java
  • python基础-面向对象编程之封装、访问限制机制和property

    面向对象编程之封装

    封装

    定义:将属性和方法一股脑的封装到对象中,使对象可通过“对象.”的方式获取或存储数据。

    作用:让对象有了"."的机制,存取数据更加方便

    # 定义类,调用类创建对象,这个过程可理解为封装
    class Teacher:
        def __init__(self, name, age, gender):
            self.name = name
            self.age = age
            self.gender = gender
    
        def score(self):
            print(f"{self.name}老师正在修改分数……")
    
    
    tea = Teacher("lee", 27, "男")
    print(tea.name, tea.age, tea.gender)
    tea.score()
    

    访问限制机制

    定义:凡是在类内部定义的属性或方法,以__开头的,都会被限制,外部不能直接访问

    这种机制看起来像是将属性和方法隐藏起来了,__开头的属性或方法,等价于 _类名__属性_类名__方法()

    作用:将隐私数据,隐藏起来,不让外部轻易获取。

    与其他编程语言的区别:

    其他语言就是私有化,限制访问。但在python中,仅仅是隐藏,这是python独有的特性

    class Person:
        __name = "lee"
        __age = 18
        __gender = "男"
    
        def __init__(self, name, age, gender):
            self.__name = name
            self.__age = age
            self.__gender = gender
    
        def __userinfo(self):
            print(f"姓名:{self.__name},年龄:{self.__age},性别:{self.__gender}")
    
    
    person = Person("dawn", 27, "男")
    print(person.__name)  # 输出报错 AttributeError: 'Person' object has no attribute '__name'
    person.__userinfo()  # 输出报错 AttributeError: 'Person' object has no attribute '__userinfo'
    
    # 被__修饰的属性或者方法,可以通过 _类名__属性或_类名__方法名() 来访问
    print(person._Person__name)  # 输出结果:dawn
    person._Person__userinfo()  # 输出结果:姓名:dawn,年龄:27,性别:男
    

    __修饰的属性和方法,只能在当前类中使用

    class A:
        def __fa(self):  # 4._A_fa()
            print('from A') # 5.最终输出的是就是 from A
    
        def test(self):  # 2.test(b) 虽然这里传入的是对象b
            self.__fa()  # 3.但是因为类的访问限制机制,这里强制换成成了 _A__fa()
    
    
    class B(A):
        def __fa(self):  # _B__fa()
            print('from B')
    
    
    b = B()
    b.test()  # 1.对象b 和当前子类B 中都没有 test(),所以去父类A中查找
    

    输出结果

    from A
    

    property

    定义: python内置的装饰器,用于将对象.方法()调整成对象.方法,类似获取属性的方式调用方法。

    作用:在某些情况下,方法返回的仅仅是处理后的数据。为了让调用者更方便的使用,将方法的调用方式修改成了类似属性的调用方式。

    class User:
        def __init__(self, weight, height):
            self.weight = weight
            self.height = height
    
        @property
        def bmi(self):
            return self.weight / (self.height ** 2)
    
    
    # 创建user对象
    user_obj = User(46, 1.56)
    # bmi()方法使用了property装饰器,调用的时候,不加()
    print(user_obj.bmi)  # 输出结果:18.902038132807363
    # 调用时,加了(),相当于user_obj.bmi()()
    print(user_obj.bmi()) # 报错 TypeError: 'float' object is not callable
    

    加了property装饰器后,调用者很容易将方法当作属性去修改或者删除.但是方法是不能通过对象.去修改删除的。

    为了让调用者可以像处理属性一样的去修改或者删除,python提供了@被装饰方法名.setter来修改方法,@被装饰方法名.delter来删除方法

    class User:
        def __init__(self, weight, height):
            # self.name = name
            self.weight = weight
            self.height = height
            self.__getbmi = self.weight / (self.height ** 2)
    
        @property  # 对象.bmi() ----→ 对象.bmi
        def bmi(self):
            return self.__getbmi
    
        @bmi.setter  # 允许修改 对象.bmi()中的值
        def bmi(self, value):
            self.__getbmi = value
    
        @bmi.deleter  # 允许删除 对象.bmi()中的值
        def bmi(self):
            del self.__getbmi
    
    
    # 创建user对象
    user_obj = User(46, 1.56)
    # print(user_obj.bmi())  # 报错,user_obj.bmi() ----→ user_obj.bmi()()
    print(user_obj.bmi)  # 输出结果:18.902038132807363
    user_obj.bmi = 18  # 修改bmi 的值。
    print(user_obj.bmi)  # 输出结果:18
    del user_obj.bmi  # 删除bmi
    print(user_obj.bmi)  # 报错,bmi 被删除了
    
  • 相关阅读:
    更改EBSserver域名/IP
    iOS Dev (60) 怎样实现 UITextView 中的 placeHolder
    程序猿的量化交易之路(29)--Cointrader之Tick实体(16)
    美团面试中被问到的问题汇总
    汇报措辞:你懂得如何向领导汇报吗(审阅、审批、审阅、批示、查阅)?
    九月份总结
    Android 编程之第三方开发 MaoZhuaWeiBo微博开发演示样例-1
    OLE操作Excel编译错误处理
    在 VS2008 下操作 Excel 的方法总结
    vs2008 ole excel
  • 原文地址:https://www.cnblogs.com/xiaodan1040/p/11946759.html
Copyright © 2011-2022 走看看