这篇文章主要介绍了如何理解Python中的self的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇如何理解Python中的self文章都会有所收获,下面我们一起来看看吧。
对于初学Python的同学来说,在class中经常看到self。那么,到底self是个啥?
这得从面向对象说起。Python从设计之初就已经是一门面向对象的语言,在Python中创建一个类和对象是很容易的。
比如,下面的代码片段:定义了一个类Employee
#!/usr/bin/python # -*- coding: UTF-8 -*- class Employee: '所有员工的基类' empCount = 0 def __init__(self, name, salary): self.name = name self.salary = salary Employee.empCount += 1 def displayCount(self): print("Total Employee %d" % Employee.empCount) def displayEmployee(self): print("Name : ", self.name, ", Salary: ", self.salary)
类,其实就是定义现实世界中的事物,人、物、等等,任何名词类的东西。比如上面定义的员工。
定义只是定义,我们定义了员工具有姓名、薪资这样的属性,但是具体到某个员工,其这些属性值一般都不一样。如何描述某个具体的员工?
有了定义,我们就可以创建实例了,这样就可以描述某个具体的员工了。其他编程语言中一般用关键字new来创建类的实例,但是在 Python 中并没有这个关键字,类的实例化类似于函数调用方式。
下面的代码:实例化Employee类
"创建 Employee 类的第一个对象" emp1 = Employee("张三", 2000) "创建 Employee 类的第二个对象" emp2 = Employee("王五", 5000)
注意:init()方法是一种特殊的方法,被称为类的构造函数或初始化方法,当创建这个类的实例的时候,就会调用该方法
而self是什么?self其实是一个占位符,代表类的实例。 当我们用上面的代码创建emp1实例的时候,它代表的是emp1这个实例;当创建emp2的时候,代表的是emp2这个实例。
因此,当我们调用下面的实例方法的时候,会分别输出实例的对应属性的值:
emp1.displayEmployee() emp2.displayEmployee()
Name : 张三 , Salary: 2000 Name : 王五 , Salary: 5000
self是与类的实例相关的。当然,类本身的一些属性和方法,是不需要实例化也存在的,千万不要搞混淆了。
比如,前面代码中的自定义的类属性empCount。以及,下面的介绍的内置属性。
Python类的内置属性
dict : 类的属性的集合:包括自定义的属性
doc :类的文档字符串
name: 类名
module: 类定义所在的模块
bases : 类的所有父类构成元素
执行:
print("Employee.__doc__:", Employee.__doc__) print("Employee.__name__:", Employee.__name__) print("Employee.__module__:", Employee.__module__) print("Employee.__bases__:", Employee.__bases__) print("Employee.__dict__:", Employee.__dict__)
输出:
Employee.__doc__: 所有员工的基类
Employee.__name__: Employee
Employee.__module__: __main__
Employee.__bases__: (<class 'object'>,)
Employee.__dict__: {'__module__': '__main__', '__doc__': '所有员工的基类', 'empCount': 2, '__init__': <function Employee.__init__ at 0x0000025F73518550>, 'displayCount': <function Employee.displayCount at 0x0000025F735185E0>, 'displayEmployee': <function Employee.displayEmployee at 0x0000025F73518670>, '__dict__': <attribute '__dict__' of 'Employee' objects>, '__weakref__': <attribute '__weakref__' of 'Employee' objects>}
还有一些Python中的内置方法,在某种情况下,会自动执行。
init
前面说过的,在实例化的时候,会被调用执行
new
在__init__触发前自动触发,调用该类时,方法是真正的类构造方法,用于产生实例化对象(空属性)。因此,可以重写__new__方法来控制对象的产生过程
del
用于当对象的引用计数为0时自动调用。一般被垃圾回收处理时调用。
在class里面,是不是必须使用self
不一定,比如我们定义”静态类“的时候:
class util: def checkEmployee(emp): if isinstance(emp, Employee): print("Name : ", emp.name, ", Salary: ", emp.salary) else: print("%s不是Employee" % emp)
假如,我们设计了一个工具类util:用来检测传入的参数是不是Employee类型,如果是的话,才进一步处理。
看下面的代码片段:
emp3 = "李四" util.checkEmployee(emp1) util.checkEmployee(emp2) util.checkEmployee(emp3)
输出:
Name : 张三 , Salary: 2000
Name : 王五 , Salary: 5000