如何理解Python中的self

这篇文章主要介绍了如何理解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

关于“如何理解Python中的self”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“如何理解Python中的self”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注蜗牛博客行业资讯频道。

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:niceseo99@gmail.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

评论

有免费节点资源,我们会通知你!加入纸飞机订阅群

×
天气预报查看日历分享网页手机扫码留言评论电报频道链接