编程小白的自学笔记五(Python类的方法
目录
前言
一、实例方法
二、类方法
1、第一个输出结果
2、第二和第三个输出结果
(1)增加输出语句
(2) 增加传参
总结
前言
Python是一种面向对象的编程语言,类是其中最基本的概念。类可以看做是一种抽象数据类型,其中包括属性和方法。Python类的方法包括类方法、实例方法和静态方法,可以在运行中动态创建方法。
一、实例方法
Python类的实例方法是绑定到类的实例上的方法,它们通常是在类定义中使用def语句定义的方法。实例方法使用self参数,它指向实例本身。通过self参数,实例方法可以访问实例的属性和方法。
下面是一个示例类,演示了如何定义和使用实例方法:
class Dog:
def __init__(self,n):
self.name = n
def jump(self):
print(f'{self.name}跳')
def run(self):
print(f'{self.name}跑')
dog1 = Dog('小白')
dog1.jump()
dog1.run()
这里我们可以看见jump()方法和run()方法,都self参数传入。这里如果不写self,写成其他单词也是可以,本人亲测有效,但是我们还是按照约定俗成的来。运行结果为:
小白跳
小白跑
总之,实例方法是Python类中非常重要的一个特性,它们允许类和对象之间的交互和通信。
二、类方法
类方法是在方法名上加上“@classmethod”修饰符,这样就可以实例名.方法名和类名.方法名访问(正常情况下,类名.方法名是会报错的),类方法是绑定到类而不是实例的方法,可以通过类来调用,也可以通过实例来调用。类方法的第一个参数通常是“cls”,这个参数指向类本身。可以使用类方法来访问类属性和调用其他类方法。。具体例子代码如下:
class Dog:
name = 'xiaohuang'
def __init__(self,name):
self.name = name
def jump(self):
print(f'{self.name}跳')
@classmethod
def run(cls):
print(f'{cls.name}跑')
dog1 = Dog('小白')
dog1.jump()
dog1.run()
Dog.run()
这里对我来说理解难度比较大,想了很长时间,代码也反复进行修改最终运行成功,运行结果是:
小白跳
xiaohuang跑
xiaohuang跑
我们一起来分析下:
1、第一个输出结果
第一个输出结果是“小白跑”,不难理解,和实例方法一样,先创建了一个实例dog1,把“小白”参数传了进去,然后调用dog1的jump()方法,输出结果,此时的self.name是“小白”。
2、第二和第三个输出结果
dog1.run()的结果竟然是“xiaohuang跑”,为什么不是“小白跑”?我的分析结果是因为加了“@classmethod”修饰符的原因,dog1在调用run()方法时,系统会重新调用__init__方法,也就是创建新的实例,这时因为没有传参进去,所以使用了默认值“xiaohuang”,为此我进行了实验:
(1)增加输出语句
我在__init__方法里增加一段输出语句 print('调用我一次'),按照上面的猜测,那么应该会输出三次“调用我一次”,但结果是只有一开始输出了,只输出了一次,dog1.run()和Dog.run()两个方法并没有重新调用__init__方法。由此证明我上面的猜测是错误的。
(2) 增加传参
基于上面的实验失败,我再次进行猜想,如果没有重新调用__init__方法,会得到这样的结果是因为加了“@classmethod”修饰符后,调用run()方法,cls代表实例本身,那么cls.name会重新调用类定义的name变量,与__init__方法无关,于是我给run()方法增加了传参, 代码如下:
def run(cls,name):
cls.name = name
print(f'{cls.name}跑')
dog1 = Dog('小白')
# dog1.jump()
dog1.run('bbb')
Dog.run('aaaa')
输出结果为:
bbb跑
aaaa跑
与我想要的输出结果一致,这次我应该是对的
总结
类方法我的个人理解不一定正确,欢迎各位批评指正。
- 点赞
- 收藏
- 关注作者
评论(0)