一文带你全面理解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
到此这篇关于一文带你全面理解Python中的self的文章就介绍到这了,更多相关Python self内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
相关文章