【python 面向对象 class 封装】

【python 面向对象 class 封装】

# 封装
# Python并没有真正的私有化支持,但可用下划线得到伪私有 访问私有变量:实例._类名__变量名 访问私有方法:实例._类名__方法名()
class Wife02():
    def __init__(self,name,age,sex):  # 负责对象的初始化
        self.set_name(name)
        self.set_age(age)
        self.set_sex(sex)

    def set_name(self,value):
        if isinstance(value,str):  # 数据类型是否是字符串
            if '\u4e00' <= value <= '\u9fff':  # 是否是正文
                self.__name = value
            else:
                raise ValueError("不是中国人")  # 抛出异常
        else:
            raise ValueError("数据类型错误")

    def set_age(self,value):
        if 18 <= value <= 100:
            self.__age = value  # 私有化实例变量:在变量名称前,加入双下划线。
        else:
            raise ValueError("年龄不符,请重新创建对象")

    def set_sex(self,value):
        if value == "女":
            self.__sex = value
        else:
            raise ValueError("性别错误")

    def get_name(self):
        return self.__name  # 返回私有变量的值

    def get_age(self):
        return self.__age

    def get_sex(self):
        return self.__sex

# w01 = Wife02("zs",20,"女")  # ValueError: 不是中国人
# w02 = Wife02("张三",8,"女")  # ValueError: 年龄不符,请重新创建对象
# w03 = Wife02("张三",8,"男")  # ValueError: 年龄不符,请重新创建对象
w04 = Wife02("张三",20,"女")
print(w04._Wife02__age)  # 访问私有变量
print(w04.get_age())  # 访问私有变量
print(w04.__dict__)  # {'_Wife02__name': '张三', '_Wife02__age': 20, '_Wife02__sex': '女'}
w04.set_age(30)  # 修改私有变量的值
print(w04.__dict__)  # {'_Wife02__name': '张三', '_Wife02__age': 30, '_Wife02__sex': '女'}
w04.sex = "男"  # 增加非私有化属性
print(w04.__dict__)  # {'_Wife02__name': '张三', '_Wife02__age': 30, '_Wife02__sex': '女', 'sex': '男'}
#################################################################################################
class Wife03():
    # 类的设计者,限制该类对象只能有如下的实例变量
    __slots__ = ("__age","sex")  # 该类只有这两个属性
    def __init__(self,age,sex = ""):
        self.age = age  # 属性
        self.sex = sex  # 实例变量

    @property  # 负责age属性的读取操作 装饰器
    def age(self):
        return self.__age

    @age.setter  # 负责age属性的写入操作
    def age(self,value):
        if 18 <= value <= 100:
            self.__age = value  # 私有化实例变量:在变量名称前,加入双下划线。
        else:
            raise ValueError("年龄不符,请重新创建对象")

w05 = Wife03(30)  # 调用的@age.setter下函数
print(w05.age)  # 调用的@property下函数
w05 = Wife03(20)  # 调用的@age.setter下函数
print(w05.age)  # 调用的@property下函数
# print(w05.__dict__)  # 报错 当定义了__slots__属性之后,Python对象将不再拥有__dict__属性和__weakref__属性
print(w05.__slots__)  # ('__age', 'sex')
print(w05._Wife03__age)
print(dir(w05))  # 属性列表['_Wife03__age', '__class__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__slots__', '__str__', '__subclasshook__', 'age', 'sex']

#################################################################################################
# 核心思想:分而治之   封装变化
class Person:
    def __init__(self, name):
        self.name = name
    @property
    def name(self):
        return self.__name
    @name.setter
    def name(self, value):
        self.__name = value
    def go_home(self, car):
        print(self.name, end="")
        car.run("家")
class Car:
    def run(self, pos):
        print("移动到" + pos)
zs = Person("张三")
car = Car()
zs.go_home(car)
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值