python进阶(四)~~~魔术方法

魔术方法

在python中,以双下划线开头、双下划线结尾的方法我们称之为魔术方法。例如__init__

魔术方法是python内部定义好的,我们不需要去创建。

1.__new__方法和单例模式

__new__方法:Create and return a new object.创建对象时触发
class Hero(object):

    def __init__(self,name):    # 对对象进行初始化
        print("这是init方法")
        self.name=name

    def __new__(cls,*args,**kwargs):    # 创建对象
        print("这是new方法")
        return super().__new__(cls)  # 必须返回原方法 创建对象的功能。如果缺少改行,h1返回值为None

h1=Hero("musen")
print(h1.name)

  应用:

  1. 重写new方法,返回其他的类对象;

  2.单例模式: 通常类每次实例化都会创建一个对象,通过单例模式可以实现限制 一个类只创建一个对象共用;

  单例模式实现思路:

  1.创建一个类属性记录是否创建过对象;

  2.在__new__方法中对类属性做出判断:如果没有创建,就新建一个对象并修改1种属性值;如果创建过,直接返回已创建的对象;

class Myclass(object):
    '''单例模式类'''
    instance=None

    def __new__(cls,*args,**kwargs):    # 创建对象
        if not cls.instance:
            cls.instance=object.__new__(cls)
            return cls.instance
        else:
             return cls.instance

h1=Myclass()
h2=Myclass()
h3=Myclass()
print(id(h1),id(h2),id(h3))

 2.上下文管理器

  通过with实现,底层使用两个魔术方法:object.__enter__()、object.__exit__()。一个类中只要使用了这两个方法,那么该类就实现了上下文协议,就是一个上下文管理器;

  object.__enter__(self): 输入此对象运行时使用的相关上下文;

  object.__exit__(self,exc_type,exc_val,exc_tb):  参数:异常类型、异常值、异常回溯

class Myopen(object):

    def __init__(self,filename,mode,encoding):
        self.filename=filename
        self.mode=mode
        self.encoding=encoding
        self.f=open(self.filename,self.mode,encoding=self.encoding)

    def __enter__(self):
        return self.f  # 返回打开的文件

    def __exit__(self,exc_type,exc_val,exc_tb):
        self.f.close()  # 关闭文件
     print(
exc_type,exc_val,exc_tb) #当执行出错时,打印出错误信息
with Myopen("1.txt","r",encoding="utf8") as f:
    print(f.read())

  上下文管理器的应用举例:

class Testcase(Myopen,unittest.TestCase):

    def __init__(self,*args,**kwargs):
        Myopen.__init__(self,*args,**kwargs)
        self,*args,**kwargs.__init__(self,*args,**kwargs)
        print("__init__")

t=Testcase()

3.__call__方法 : 在对象使用括号时被触发,使类创建的对象像函数一样可以被引用

class Test(object):

    def __call__(self):
        print("触发了call方法")

t=Test()
t()  # 触发了call方法

4.__str__方法、__repr__方法

  __str__方法:print()、str()、format() 触发

  __repr__方法:交互环境>>>下直接输入变量时、repr转换对象时 触发;当找不到__str__方法,只有__repr__方法时,上述3种均触发__repr__方法

  应用:打印类的一些属性

class Hero(object):
    def __init__(self,name):
        self.name=name

    def __str__(self):
        return self.name

h=Hero('musen')
print(h)

5. 算术运算的实现

  __add__(slef,other): 相加  +,以+触发

  __sub__(slef,other): 相减  -

  __mul__(slef,other): 相乘 *

  __truediv__(slef,other): 定义真除法 /

  __floordiv__(slef,other): 定义整数除法 //

  __mod__(slef,other): 定义取余算法 %

class Mystr(object):
    
    def __init__(self,value):
        self.value=value

    def __str__(self):
        return self.value
    
    def __add__(self,other):   # self代表实例本身,other代表其他
        return Mystr(F'{self.value}{other.value}')
  def __sub__(self,other):
return self.value.replace(other.value,'')
s1
=Mystr("aaa") s2=Mystr("bbb") print(s1+s2)

 

posted @ 2020-02-08 00:44  青域  阅读(423)  评论(0编辑  收藏  举报