Python基础学习009——类的封装

# 面向对象是一种编程思想,还有另一种是面向过程
# 面向过程,具体步骤的实现,所有功能都自己书写
# 面向对象,使用一个个工具(函数),帮助完成各项任务
# 类:对多个特性相同或相似的食物的统称,根据特征不同一个事物可以属于多个类
# 对象:由类实例化的一个事物,指代1个
# 类的组成:类名(大驼峰),属性即类的特征,方法即类要做什么事
# 类的抽象:找到类名,属性和方法
"""
1.定义类:定义前先设计类
2.创建对象:使用第一步定义的类创建对象
3.通过对象调用方法
"""


# 定义类
class Person:
    def run(self):  # 方法的本质是在类中定义的函数,只不过要带一个self参数
        print("跑起来")
        print(id(self))


# 创建对象Person()形式即可创建对象,只不过这样不能使用,需要一个变量把对象保存起来
# 变量 = 类名()形式,变量中保存的是对象的引用,可以说变量a就是对象A
# 一个类可以创建多个对象,每个对象的地址都不一样
xiaoming = Person()
# 调用对象
xiaoming.run()

# self:从函数的语法上说,self是形参,可以是任意变量名,只不过习惯将它写作self
# self是普通形参,但调用的时候可以不传递实参值,不符合函数语法.
# 实际是Python解释器在调用这个方法的时候自动将调用这个方法的对象,即xiaoming,传递给self
# 所以self本质是一个对象.验证:self的引用和调用小明的引用一致
print(id(xiaoming))  # 此处结果与上一行调用时run方法结果一致


# ------------------------------------------------------------
# 添加属性 对象.属性名 = 属性值
# 1.类内部添加:self.属性名 = 属性值,一般添加在_init_方法中
# 2.类外物添加:对象.属性名 = 属性值,一般不用

# 获取属性:对象.属性名
# 1.类内部获取:self.属性名
# 2.类外部获取:对象.属性名,一般不使用


class Cat:
    def eat(self):
        print(f'小猫{self.name}吃鱼')


black_cat = Cat()
black_cat.name = '黑黑'  # 在外部添加属性
black_cat.eat()


# --------------------------------------------------
# 魔法方法:以两个下划线开头,两个下划线结尾,在满足某个条件的情况下会自动调用


class Dog:
    def __init__(self, n, a):
        self.name = n
        self.age = a

    def __str__(self):
        return f'今年{self.age}岁了'

    def show(self):
        print(f'小狗{self.name}')


# 魔法方法在什么情况下自动调用
# 创建对象后自动调用
white_dog = Dog('巴顿', 2)  # 在这一步就已经调用了__init__
# 用在哪:给对象添加属性(初始化方法,构造方法).某行代码在每次创建对象后都要执行,就可以写在__init__中
# 注意事项:不要漏_,不要拼错名称init,如果init方法出了self之外的形参,必须传参
white = white_dog  # 没有创建对象,只是给对象一个别名,只有类名()形式才是创建对象
white.show()  # 别名与原名同样使用

# ---------------------------------------------
# __str__方法:
# 什么情况下自动调用:使用print打印对象时,这个方法中一般书写对象的属性信息,
# 用在哪:即想要在对象打印时输出什么内容,就把对应内容写进这个函数默认输出对象的引用地址
# 注意事项:必须返回一个字符串
print(white_dog)


# -------------------------------------------
# __del__:对象被销毁是自动调用(处理后事)
# 使用del删除对象,或者代码全部运行结束,声明周期到,销毁对象
# 如果对象有多个名字,即多个对象引用一个对象,需要把所有跟这个对象有关的名称都删除才行
class demo:
    def __init__(self, n):
        self.name = n
        print('调用了init')

    def __del__(self):
        print(f"调用del,{self.name}要删除")


a = demo('zhangsan')
b = demo('liso')
c = demo('adfs')
cc = c
del cc  # cc只是对象c的其中一个名称,只删除cc是不会调用__del__的,
print("此语句执行在删除adfs前")
del c  # 与对象c有关的名称全部被删除,则调用__del__销毁
print('此语句执行在删除adfs后')
del a  # 特意声明删除对象a,此时调用__del__销毁对象a
print("zhangsan销毁后")
print("代码结束,此句后销毁剩余未销毁的对象,即对象b")


# ---------------------------------------------------------------------------------
class House:
    def __init__(self, House_type, House_area):
        self.House_type = House_type  # 房型
        self.House_area = House_area  # 总面积
        self.Last_area = House_area  # 剩余面积
        self.item_list = []  # 家具列表

    def __str__(self):
        return f'户型:{self.House_type}\n总面积:{self.House_area}\n剩余面积:{self.Last_area}\n家具:{self.item_list}'

    def add_item1(self, *args):
        for i in args:
            if self.Last_area > i.get('area'):
                self.item_list.append({'name': i.get('name'), 'area': i.get("area")})
                self.Last_area -= i.get('area')
        else:
            print('剩余面积不足')

    def add_item2(self, item):
        if self.Last_area > item.area:
            self.item_list.append({'name': item.name, 'area': item.area})
            self.Last_area -= item.area
        else:
            print('剩余面积不足')


class Furniture:
    def __init__(self, name, area):
        self.name = name
        self.area = area

    def __str__(self):
        return f'家具:{self.name},占地面积:{self.area}'


house1 = House('三室一厅', 100)
house1.add_item1({'name': '衣柜', 'area': 2}, {'name': '餐桌', 'area': 1.5})
print(house1)
bed = Furniture('席梦思', 4)
chest = Furniture('衣柜', 2)
table = Furniture('餐桌', 1.5)
house1.add_item2(bed)
print(house1)

你可能感兴趣的:(Python,python,学习,开发语言)