ToB企服应用市场:ToB评测及商务社交产业平台

标题: python教程:__new__ 和 __init__及cls和self [打印本页]

作者: 吴旭华    时间: 2024-4-9 11:47
标题: python教程:__new__ 和 __init__及cls和self
1、__new__ 和 __init__

两者的区别:
也就是: __new__先被调用,__init__后被调用,__new__的返回值(实例)将传递给__init__方法的第一个参数,然后__init__给这个实例设置一些参数;
说明:
举例:
下面的例子init不会执行,  因为init是在new返回创建的实例时才调用的(这里new并没有返回), new方法返回的实例会作为init的self参数:
  1. class A(object):
  2.     def __new__(cls):
  3.         print('new')
  4.                              
  5.     def __init__(self):                                    
  6.         print('init')
  7.                                                   
  8. A()
  9. # 输出
  10. new
复制代码
下面这个例子init就会执行了:
  1. class A(object):
  2.     def __new__(cls):
  3.         return super().__new__(cls)
  4.     def __init__(self):
  5.         print('init')
  6. A()
  7. # 输出
  8. init
复制代码
这样我们就可以自定义类的创建过程:
  1. class Female:
  2.     def __str__(self):
  3.         return "I'm Female"
  4. class Male:
  5.     name = "w"
  6.     def __new__(cls):
  7.         if cls.name == "w":
  8.             return super().__new__(Female)
  9.     def __init__(self):
  10.         return "I'm Male"
  11. print(Male())
  12. # 输出
  13. I'm Female
复制代码
2、cls和self

cls 和 self其实只是一种命名习惯习惯, 是在PEP8中定义的.
cls:
cls作为第一个参数用来表示类本身. 在类方法中用到;
类方法是只与类本身有关而与实例无关的方法;
如果不想通过实例来调用类的函数属性,而直接用类调用函数方法,则这就是类方法,通过内置装饰器@calssmethod
  类名.类方法()
  类方法只是给类使用(无论是否存在实例),只能访问实例属性(变量)
如下:
  1. class A(object):
  2.     a = 'a'
  3.     @classmethod  # @classmethod是用来指定一个类的方法为类方法
  4.     def repeat_a(cls, num=1):
  5.         return cls.a * num
  6. foo = A()
  7. print(foo.repeat_a(2))
  8. # 输出
  9. aa
复制代码
self:
self作为第一个参数用来表示类的实例, 在类的一般方法中用到. 类的一般方法与类的实例有关;
@staticmethod 静态方法只是名义上归属类管理,但是不能使用类变量和实例变量,是类的工具包,
放在函数前(该函数不传入self或者cls),所以不能访问类属性和实例属性
  1. DEBUG = True
  2. class A(object):
  3.     a = 'a'
  4.         #学习中遇到问题没人解答?小编创建了一个Python学习交流群:711312441
  5.     @staticmethod  #类中的一种静态方法, 用@staticmethod装饰器装饰,
  6.     def is_debug():
  7.         return DEBUG
  8.     def show_error_messages(self):
  9.         if self.is_debug():
  10.             print('error_messages')
  11.         else:
  12.             print("123")
  13. foo = A()
  14. foo.show_error_messages()
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4