第6章 向对象初步
继承、多台、封装
- 面向对象思考方式
遇到复杂问题,先从问题中找名词(面向过程更多的是找动词),然后确立这些名词哪些可以作为类,再根据问题需求确定的类的属性和方法,确定类之间的关系。
类
定义类的语法格式如下:
class 类名:
类体
- 类名首字母大写
- 类体中定义属性和方法
- 属性-描述数据; 方法/函数 - 描述数据的操作
类的定义示例:
class Student:
def __init__(self,name,score):
self.name = name
self.score = score
def say_score(self):
print(self.name,'的分数是:',self.score)
s1 = Student('张三',80)
s1.say_score()
__init__构造方法和__new__方法
创建对象,我们需要定义构造函数__init__()方法。构造方法用于执行“实例对象的初始化工 作”,即对象创建后,初始化当前对象的相关属性,无返回值。
init()的要点如下:
- 名称固定,必须为:init()
- 第一个参数固定,必须为:self。 self 指的就是刚刚创建好的实例对象。
- 构造函数通常用来初始化实例对象的实例属性,如下代码就是初始化实例属性:name 和 score。
def __init__(self,name,score):
self.name = name
self.score = score
- 通过“类名(参数列表)”来调用构造函数。调用后,将创建好的对象返回给相应的变量。 比如:s1 = Student(‘张三’, 80)
- init()方法:初始化创建好的对象,初始化指的是:“给实例属性赋值”
- new()方法: 用于创建对象,但我们一般无需重定义该方法。
- 如果我们不定义__init__方法,系统会提供一个默认的__init__方法。如果我们定义了带参 的__init__方法,系统不创建默认的__init__方法。
8.Python中,self 必须为构造函数的第一个参数,名字可以任意修改。但一般遵守惯例,都叫做 self。
实例属性
实例属性是从属于实例对象的属性,也称为“实例变量”。 要点:
- 实例属性一般在__init__()方法中通过如下代码定义:
self.实例属性名 = 初始值 - 在本类的其他实例方法中,也是通过 self 进行访问:
self.实例属性名 - 创建实例对象后,通过实例对象访问:
obj01 = 类名() #创建对象,调用__init__()初始化属性 obj01.实例属性名 = 值 #可以给已有属性赋值,也可以新加属性
实例方法
实例方法是从属于实例对象的方法。 实例方法的定义格式如下:
def 方法名(self [, 形参列表]):
函数体
方法的调用格式如下:
对象.方法名([实参列表])
要点:
- 定义实例方法时,第一个参数必须为 self。和前面一样,self 指当前的实例对象。
- 调用实例方法时,不需要也不能给 self 传参。self 由解释器自动传参。
其他操作
- dir(obj)可以获得对象的所有属性、方法
- obj.dict 对象的属性字典
- pass 空语句
- isinstance(对象,类型) 判断“对象”是不是“指定类型”
静态方法
- Python 中允许在类中定义与“类对象”无关的方法,称为“静态方法”。
- 如果要使用该静态方法,需要通过类调用。这是静态方法和普通函数的唯一区别。其他都一样。
- 静态方法通过装饰器@staticmethod 来定义,格式如下:
@staticmethod
def 静态方法名([形参列表]) : 函数体
- @staticmethod 必须位于方法上面一行
- 调用静态方法格式:“类名.静态方法名(参数列表)”
- 静态方法中访问实例属性和实例方法会导致错误,无权限访问实例对象
class Student:
company = "SXT"
@staticmethod
def add(a, b):
print("{0}+{1}={2}".format(a,b,(a+b)))
return a+b
Student.add(20,30)
__del__方法(析构函数)和垃圾回收机制
__del__方法称为“析构方法”,用于实现对象被销毁时所需的操作。比如:释放对象 占用的资源,例如:打开的文件资源、网络连接等。
Python 实现自动的垃圾回收,当对象没有被引用时(引用计数为 0),由垃圾回收器 调用__del__方法。
__call__方法和可调用对象
定义了__call__方法的对象,称为“可调用对象”,即该对象可以像函数一样被调用。
class SalaryAccount:
'''工资计算类'''
def __call__(self, salary):
yearSalary = salary*12
daySalary = salary//30
hourSalary = daySalary//8
return
dict(monthSalary=salary,yearSalary=yearSalary,daySalary=daySalary
,hourSalary=hourSalary)
s = SalaryAccount()
print(s(5000))
结果:
{'monthSalary': 5000, 'yearSalary': 60000, 'daySalary': 166, 'hourSalary': 20}
方法没有重载
如果我们在类体中定义了多个重名的方法,只有最后一个方法有效。 不要使用重名的方法! Python 中方法没有重载。
|