Python_从零开始学习_(35) 类的基本使用
目录
- 定义简单的类 (只包含方法)
1.1 定义只包含方法的类
1.2 创建对象
1.3 第一个面向对象程序
- 方法中的 self 参数
2.1 给对象增加属性
2.2 使用 self 在方法内部输出每一只猫的名字
- 初始化方法
3.1 之前代码存在的问题 —— 在类的外部给对象增加属性
3.2 初始化方法
3.3 在初始化方法内部定义属性
3.4 改造初始化方法 —— 初始化的同时设置初始值
- 内置方法和属性
4.1 __del__方法
4.2 __str__方法
1. 定义简单的类 (只包含方法)
面向对象 是 更大 的 封装, 在 一个类中 封装 多个方法, 这样 通过这个类创建出来的对象, 就可以直接调用这些方法了!
1.1 定义只包含方法的类
在 Python 中要定义一个只包含方法的类, 语法格式如下:
class 类名:
def 方法1(self, 参数列表):
pass
def 方法2(self, 参数列表):
pass
方法 的定义格式和之前学习过的 函数 几乎一样
- 区别在于第一个参数必须是 self
注意: 类名 的 命名规则 要符合 大驼峰命名法
1.2 创建对象
当一个类定义完成之后, 要使用这个类来穿件对象, 语法格式如下
对象变量 = 类名()
1.3 第一个面向对象程序
需求
- 小猫 爱 吃 鱼, 小猫 要 喝 水
分析
- 定义一个猫类 Cat
- 定义两个方法 eat 和 drink
按照需求 —— 不需要定义属性
class Cat:
"""这是一个猫类"""
def eat(self):
print("小猫爱吃鱼")
def drink(self):
print("小猫要喝水")
# 创建猫对象
tom = Cat()
tom.eat()
tom.drink()
引用概念的强调
在面向对象开发中, 引用的概念是同样适用的!
- 在 Python 中使用类 创建对象之后, tom 变量中 仍然记录的是 对象在内存中的地址
- 也就是 tom 变量 引用 了 新建的猫对象
- 使用 print 输出 对象变量, 默认情况下, 是能够输出这个变量 引用的对象 是哪一个类创建的对象, 以及 在内存中的地址 (十六进制表示)
提示 : 在计算机中, 通常使用 十六进制 表示 内存地址
- 十进制 和 十六进制 都是用来表达数字的, 只是表示的方式不一样
- 十进制 和 十六进制 的数字之间可以来回转换
- %d 可以以 10 进制 输出数字
- %x 可以以 16 进制 输出数字
案例进阶 —— 使用 Cat 类再创建一个对象
lazy_cat = Cat()
lazy_cat.eat()
lazy_cat.drink()
提问: tom 和 lazy_cat 是同一个对象吗? 不是!
2. 方法中的 self 参数
2.1 给对象增加属性
- 在 Python 中, 要 给对象设置属性, 非常的容易, 但是不推荐使用
- 因为: 对象属性的封装应该封装在类的内部
- 只需要在 类的外部的代码 中直接通过 . (点) 设置一个属性即可
注意: 这种方式虽然简单, 但是不推荐使用!
tom.name = "Tom"
lazy_cat.name = "大懒猫"
2.2 使用 self 在方法内部输出每一只猫的名字
由 哪一个对象 调用的方法, 方法内的 self 就是 哪一个对象的引用
- 在类封装的方法内部, self 就表示 当前调用方法的对象自己
- 调用方法时, 程序员不需要传递 self 参数
- 在方法内部
- 可以通过 self. 访问对象的属性
- 也可以通过 self. 调用其他的对象方法
例如 :
class Cat:
"""这是一个猫类"""
def eat(self):
print("%s 爱吃鱼" % self.name)
def drink(self):
print("%s 要喝水" % self.name)
# 创建猫对象
tom = Cat()
tom.name = "Tom"
tom.eat()
tom.drink()
print(tom)
# 再创建一个猫对象
lazy_cat = Cat()
lazy_cat.name = "大懒猫"
lazy_cat.eat()
lazy_cat.drink()
print(lazy_cat)
- 在 类的外部, 通过 变量名. 访问对象的 属性和方法
- 在 类封装的方法中, 通过 self. 访问对象的 属性和方法
3. 初始化方法
3.1 之前代码存在的问题 —— 在类的外部给对象增加属性
将案例代码进行调整, 先调用方法 再设置属性, 观察以下执行效果
tom = Cat()
tom.name = “Tom”
tom.eat()
tom.drink()
tom.name = “Tom”print(tom)
程序报错
AttributeError: ‘Cat’ object has no attribute ‘name’
提示
- 在日常开发中, 不推荐在 类的外部 给对象增加属性
- 如果 在运行时, 没有找到属性, 程序会报错
- 对象应该包含有哪些属性, 应该 封装在类的内部
3.2 初始化方法
- 当使用 类名() 创建对象时, 会 自动 执行以下操作:
- 为对象在内存中 分配空间 -—- 创建对象
为对象的属性 设置初始值 —— 初始化方法(init)
- 这个 初始化方法 就是 __init__ 方法, __init__是对象的 内置方法
__init__ 方法是 专门 用来定义一个类 具有哪些属性的方法!
在 Cat 中增加 __init__ 方法, 验证该方法在创建对象时会被自动调用
class Cat:
"""这是一个猫类"""
def __init__(self):
print("这是一个初始化方法")
# 使用类名()创建对象的时候, 会自动调用初始化方法
tom = Cat()
3.3 在初始化方法内部定义属性
- 在 __init__ 方法内部使用 self.属性名 = 属性的初始值 就可以 定义属性
定义属性之后, 再使用 Cat 类创建的对象, 都会拥有该属性
class Cat:
"""这是一个猫类"""
def __init__(self):
print("这是一个初始化方法")
# self.属性名 = 属性的初始值
self.name = "Tom"
def eat(self):
print("%s 爱吃鱼" % self.name)
# 使用类名()创建对象的时候, 会自动调用初始化方法
tom = Cat()
tom.eat()
3.4 改造初始化方法 —— 初始化的同时设置初始值
- 在开发中, 如果希望在 创建对象的同时, 就设置对象的属性, 可以对__init__方法进行 改造
- 把希望设置的属性值, 定义成 __init__ 方法的参数
- 在方法内部使用 self.属性 = 形参 接收外部传递的参数
在创建对象时, 使用 类型(属性1, 属性2…) 调用
class Cat:
"""这是一个猫类"""
def __init__(self, new_name):
print("这是一个初始化方法")
# self.属性名 = 属性的初始值
self.name = new_name
def eat(self):
print("%s 爱吃鱼" % self.name)
# 使用类名()创建对象的时候, 会自动调用初始化方法
tom = Cat("Tom")
lazy_cat = Cat("大懒猫")
4. 内置方法和属性
序号 | 方法名 | 类型 | 作用 |
---|---|---|---|
1 | del | 方法 | 对象被从内存中销毁前, 会被 自动 调用 |
2 | str | 方法 | 返回对象的描述信息, print 函数输出使用 |
4.1 __del__方法
- 在 Python 中
- 当使用 类名() 创建对象时, 为对象 分配完空间 后, 自动 调用 __init__方法
当一个 对象被从内存中销毁 前, 会 自动 调用 __del__ 方法
- 应用场景
__init__ 改造初始化方法, 可以让创建对象更加灵活
__del__如果希望在对象被销毁前, 再做一些事情, 可以考虑一下 __del__方法
- 生命周期
一个对象从调用 类名( ) 创建, 生命周期开始
- 一个对象的 __del__ 方法一旦被调用, 生命周期结束
在对象的生命周期内, 可以访问对象属性, 或者让对象调用方法
class Cat:
def __init__(self, new_name):
# self.属性名 = 属性的初始值
self.name = new_name
print("%s 来了" % self.name)
def __del__(self):
print("%s 走了" % self.name)
# tom是全局变量,会在分割线下执行del方法
tom = Cat("Tom")
# 使用 del 关键字可以删除一个对象, 销毁了, 就会在分隔线之前执行
# del tom
print("-" * 50)
4.2 __str__方法
- 在 Python 中, 使用 print 输出 对象变量, 默认情况下, 会输出这个变量 引用的对象 是 由哪一个类创建的对象, 以及 在内存中的地址 (十六进制表示)
- 如果在开发中, 希望使用 print 输出 对象变量 时, 能够打印 自定义的内容, 就可以利用 __str__这个内置方法了
注意: __str__ 方法必须返回一个字符串
class Cat:
def __init__(self, new_name):
self.name = new_name
print("%s 来了" % self.name)
def __del__(self):
print("%s 走了" % self.name)
def __str__(self):
# 必须返回一个字符串
return "我是一只猫%s" % self.name
# tom是全局变量,会在分割线下执行del方法
tom = Cat("Tom")
print(tom)
# 打印结果
# Tom 来了
# 我是一只猫Tom
# Tom 走了
还没有评论,来说两句吧...