假设有一个类nameMain(), 如最下面代码
- 类 : 一个抽象的模板。可以理解为抽象设计图
- 类名:类的名字。
查看/实现方式 :print(nameMain)或者print(self.class) - 类的实例:即类创建的对象,类每创建一个实例就开辟新的内存地址指向这个创建的实例。抽象设计图具体实现的东西
查看/实现方式 : a=nameMain(带参/无参) - self : 表示类创建的实例/对象本身,指向当前创建对象的内存地址。在__init__魔方方法中创建
类可以创建很多不同的实例,这些实例又有自己特定的特征,如何很好的调用和匹配好 所创建的实例对象 及其特征 就需要self。
理解:
例如 :类中创建了对象a和对象b, self对象就是a和b对象的抽象的统称,关于对象a和对象b的特征,可以用self来调用,当self指向a时就指向a的内存地址,可以调用a的特征;同理self指向对象b就指向b的内存地址,就可以调用b的特征。
比如 : 可以把 对象a 和 对象b 理解成 客户a 和 客户b, 类理解为某个房子。这时候客户a和客户b都买了同一个设计图出的房子,但是他们想要自己的装修风格,这些装修风格就是对象a、对象b的特征。当装修队开始装修房子时,先选择具体客户,然后根据客户要求装修;而先服务哪个客户呢?客户就选择self客户管理工具指向的现在的客户,同时self还可以调用对象的特征,这时候根据self指示的客户和self调用客户要求的装修风格来装修房子。
- 客户a=类的对象a;
- (客户要求的)装修风格=对象a/b的特征;
- 房型=类 装修队=代码的执行
具体代码:
""" self的理解 :
1, self表示类的实例 或 对象, 指向当前对象的内存地址 (self不指向类本身,而是类创建的实例/对象)
2, 类中定义的函数的self 与 init中self的内存地址 + 创建实例的内存地址 保持一致(都指向同一个内存地址)
3, self.__class__ 用来查看当前类名,相当于print(nameMain)
"""
class nameMain(object):
def __init__(self, name, age):
print("init中的self={}".format(self))
print("self.__class__用于查看当前类名 : ", self.__class__)
self.name = name
self.age = age
def printStu(self):
print("def中的self={}".format(self))
return "name={}, age={}".format(self.name, self.age)
if __name__ == "__main__":
a = nameMain("immuable", 18)
print("a = {}".format(a)) # self 打印地址=对象a的地址
print(a.printStu())
print()
b=nameMain("muable", 100) # self 打印地址=对象b的地址
print("b = {}".format(b))
print(b.printStu())
输出
# 对象a
init中的self=<__main__.nameMain object at 0x0000022E78A2F8D0>
self.__class__用于查看当前类名 : <class '__main__.nameMain'>
a = <__main__.nameMain object at 0x0000022E78A2F8D0>
def中的self=<__main__.nameMain object at 0x0000022E78A2F8D0>
name=immuable, age=18
#对象b
init中的self=<__main__.nameMain object at 0x0000022E78A2F828>
self.__class__用于查看当前类名 : <class '__main__.nameMain'>
b = <__main__.nameMain object at 0x0000022E78A2F828>
def中的self=<__main__.nameMain object at 0x0000022E78A2F828>
name=muable, age=100
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)