前言
前两节讲解了Python面向对象的思想和Python类中各种变量的含义以及区别。肯定有小伙伴会问,类初始化时是否可以传入参数?如果有多个类中含有共同的函数方法,是否可以重复利用?本节就带着这些问题来继续深入类。Here We Go!
一、类的传参
1.1 带参数的初始化
还是以Doctor类为例,假如lisi是一位男性医生,现在要求在生成lisi这个对象时传入其性别。怎么办呢?
按照之前所学的,类似于函数的传参,肯定是:
lisi = Doctor('male')
的确,类带参数的初始化就是这么用的,那么再按照函数的思想,类源代码应该这么写:
class Doctor(name):
def talk(self):
print('My gender is {0}'.format(self.name)) lisi = Doctor('male') lisi.talk()
# 按照函数的思想,创建一个带参数的类
# 这是错误的!!!!
你已经看到,代码里已经标出这是错误的编写方法,不信的话来运行一下:
Traceback (most recent call last):
File "1.py", line 1, in <module>
class Doctor(name):
NameError: name 'name' is not defined # 竟然抛出name未定义异常
这是为什么呢?莫名其妙的竟然抛出未定义异常,关于这个问题将会放到下面(类的性质)来讲
那带参数的类要怎么编写呢?使用特殊方法 __init__(注意:init左右两边都是两个下划线) ,先来看个例子:
class Doctor():
def __init__(self, name):
¦ self.name = name def talk(self):
¦ print('My gender is {0}'.format(self.name)) lisi = Doctor('male') lisi.talk() # 运行结果:
My gender is male
通过上面的代码可以看出,要想创建一个带参数的类,类里面要创建一个__init__的方法,其实这个特殊的函数叫做构造函数,构造函数会在实例化类后默默运行一次,也就是说,只要实例化了一个类,那么就已经运行了构造函数。构造函数通常用来传入参数使用。以上就是类的传参。
1.2 类实例化后运行顺序
当一个类实例化后,类中的代码被首先运行,其次是构造函数里的代码,再然后是被调用的函数被运行,最后是析构函数被运行(析构函数将放在类的特殊方法讲)
class Doctor():
def __init__(self, name):
¦ print('我是第二个被运行的')
¦ self.name = name print('先运行我') def talk(self):
¦ print('只有调用我时才运行我') lisi = Doctor('male') lisi.talk() # 运行结果:
先运行我
我是第二个被运行的
只有调用我时才运行我
从上面的代码中可以清晰的看到每个代码块的运行顺序
二、面向对象的性质
面向对象共有三大性质:封装性、继承性、多态性。这三大性质是一定要记住的,不仅要记住,更要理解它们