1.实例方法简介

实例方法是从属于实例对象的方法。实例方法的定义格式如下:

def 方法名(self [, 形参列表]):
	函数体

实例方法的调用格式如下:

对象.方法名([实参列表])

要点:

  1. 定义实例方法时,第一个参数必须为self。和前面介绍一样,self指当前的实例对象。
  2. 调用实例方法时, 不需要也不能给self传参。self由解释器自动传参

函数和方法的区别:

  • 都是用来完成一个功能的语句块,本质都是实现功能。
  • 实例方法调用时,通过实例对象来调用。实例方法从属于特定实例对象,普通函数没有这个特点。
  • 直观上看,方法定义时需要传递self,函数不需要。

2.实例方法底层说明

2.1 引题

使用两种方法调用实例方法,来说明情况:

class Student:
    def __init__(self, name, score):
        self.name = name
        self.score = score

    def say_score(self):
        print("{0}的分数是:{1}".format(self.name, self.score))

print("常规调用方法")
a = Student("学生a", 2)
a.say_score()

print("--" * 20)
print("实际的调用方法")
Student.say_score(a)

运行结果:

常规调用方法
学生a的分数是:2
----------------------------------------
实际的调用方法
学生a的分数是:2

2.2 初步结论

运行上面的代码,我们发现: 运行的结果是一致的。从而引出下面的简单结论:

实例对象的方法调用本质:
实例方法调用本质

2.3 进一步的内存结构说明

实例方法内存结果
说明: 实例方法虽然从属于对象,但是在类中共享,这也是第二种方法,通过类寻找实例方法,传递对应的实例对象的就可以执行对应的功能。

这也从另外一个角度来说明:为什么在python中定义实例方法的时候为什么第一个参数始终是self,因为方法如上图一样,共享在类中,为了区分到底哪个对象调用方法,需要把对应对象也要传递过来。

3.dir()方法和__dict__属性

dir(obj)可以获得对象的所有属性列表, 而obj.__dict__对象的自定义属性字典
注意事项:

  1. dir(obj)获取的属性列表中,方法也认为属性的一种。返回的是list
  2. obj.__dict__只能获取自己自定义的属性,系统内置属性无法获取。返回是dict

代码说明:

class Student:
    def __init__(self, name, score):
        self.name = name
        self.score = score
 
s1 = Student("聂发俊", 100)
print("获取所有的属性列表")
print(dir(s1))

print("--" * 20)
print("获取自定义属性字段")
print(s1.__dict__)

运行结果:

获取所有的属性列表
['__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', 'name', 'score']
----------------------------------------
获取自定义属性字段
{'name': '聂发俊', 'score': 100}

4.isinstance()方法

官方解释:

"""
Return whether an object is an instance of a class or of a subclass thereof.
"""

返回一个对象是否是一个类或者其子类的实例。(注意子类的情况

代码说明:

class A(object):
    pass

class B(A):
    """代表类B继承类A"""
    pass

class C:
    pass

b1 = B()
print(isinstance(b1, A))
print(isinstance(b1, B))
print(isinstance(b1, C))

运行结果:

True
True
False

解释: 对象b1是通过类B创建出来的,所以对象b1是类B是属于实例关系,第二个结果为True。类B是类A的子类,也就是对象b1是类A的子类B的实例,第一个结果为True。对象b1和类C没有关系,所以第三个为False。


备注:
更多精彩博客,请访问:聂发俊的技术博客
对应视频教程,请访问:python400
完整markdown笔记,请访问: python400_learn_github