007_Python中的__init__,__call__,__new__

__init__函数

当一个类实例被创建时, __init__() 方法会自动执行,在类实例创建完毕后执行,类似构建函数。__init__() 可以被当成构建函数,不过不象其它语言中的构建函数,它并不创建实例--它仅仅是你的对象创建后执行的第一个方法。它的目的是执行一些该对象的必要的初始 化工作。通过创建自己的 __init__() 方法,你可以覆盖默认的 __init__()方法(默认的方法什么也不做),从而能够修饰刚刚创建的对象__init__()需要一个默认的参数self,相当于this。

__call__函数

Python中有一个有趣的语法,只要定义类型的时候,实现__call__函数,这个类型就成为可调用的。

换句话说,我们可以把这个类的对象当作函数来使用,相当于重载了括号运算符。为了弄明白python中__setattr__, __getattr__, __delattr__, __call__的作用,重写dict,扩展其功能。

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#
# Copyright 2015 mimvp.com

class MyDict(dict):
    ‘‘‘
    通过使用__setattr__, __getattr__, __delattr__
    可以重写dict,使之通过“.”调用
    ‘‘‘

    def __init__(self):
        super(MyDict, self).__init__()

    def __setattr__(self, key, value):
        self[key] = value

    def __getattr__ (self, key):
        try:
            return self[key]
        except KeyError, e:
            print ‘__getattr__ error_msg: %r‘ % e
            return None

    def __delattr__ (self, key):
        try:
            del self[key]
        except KeyError, e:
            print ‘__delattr__ error_msg: %r‘ % e
            return None

    def __call__ (self, key):
        ‘‘‘ 用于实例自身的调用, 达到()调用的效果 ‘‘‘
        try:
            return self[key]
        except KeyError, e:
            print ‘__delattr__ error_msg: %r‘ % e
            return None

def main():
    s = MyDict()
    s.name = "mimvp.com"                    # 这是__setattr__起的作用
    print "s(‘name‘) : %s" % s(‘name‘)      # 这是__call__起的作用
    print "s[‘name‘] : %s" % s[‘name‘]      # dict默认行为
    print "s.name : %s" % s.name            # 这是__getattr__起的作用

    del s.name                              # 这是__delattr__起的作用
    print "s.name2 : %s" % s.name           # 这是__getattr__起的作用

if __name__ == ‘__main__‘:
    main()
    print("end.")

运行结果:

s(‘name‘) : mimvp.com
s[‘name‘] : mimvp.com
s.name : mimvp.com
__getattr__ error_msg: KeyError(‘name‘,)
s.name2 : None
end.

-------------

Python中的__init__ 、__new__、__call__小结

1.__init__(self, *args, **kwargs)

创建完对象后调用,对当前对象的实例的一些初始化,无返回值,即在调用__new__之后,根据返回的实例初始化;注意这里的第一个参数是self,即对象本身(注意和new的区别)

2.__new__(cls, *args, **kwargs) 

创建对象时调用,返回当前对象的一个实例,注意这里的第一个参数是cls即class本身

3.__call__(self,  *args, **kwargs)

如果类实现了这个方法,相当于把这个类型的对象当作函数来使用,相当于 重载了括号运算符

具体例子:

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#
# Copyright 2015 mimvp.com
class MyClass(object):
    def __init__(self, *args, **kwargs):
        print "init"
        super(MyClass, self).__init__(*args, **kwargs)
    def __new__(cls, *args, **kwargs):
        print "new", cls
        return super(MyClass, cls).__new__(cls, *args, **kwargs)
    def __call__(self, *args, **kwargs):
        print "call"
def main():
    myclass = MyClass()
    myclass()
if __name__ == ‘__main__‘:
    main()
    print("end.")

运行结果:

new <class ‘__main__.MyClass‘>
init
call
end.

比如:Python Singleton(单例模式)实现,那我们是不是只是重载一些__new__方法就可以了

class Singleton1(object):
    """ 重载new方法"""
    def __new__(cls, *args, **kwargs):
        if not "_instance" in vars(cls):
            cls._instance = super(Singleton1, cls).__new__(cls, *args, **kwargs)
            return cls._instance

可不可以重载__init__方法呢?明显不可以,因为__init__之前调用了__new__方法,这时候已经生成了一个对象了,没办法实现单例模式

参考:http://blog.mimvp.com/2015/01/python-initcallnew/

时间: 2024-10-15 06:00:44

007_Python中的__init__,__call__,__new__的相关文章

Python中的__init__和__new__

一.__init__ 方法是什么? 使用Python写过面向对象的代码的同学,可能对 __init__ 方法已经非常熟悉了,__init__ 方法通常用在初始化一个类实例的时候.例如: # -*- coding: utf-8 -*- class Person(object): """Silly Person""" def __init__(self, name, age): self.name = name self.age = age def

python中的__init__和__new__的区别

一.__init__ 方法是什么?(init前后的线是双下划线) 使用Python写过面向对象的代码的同学,可能对 __init__ 方法已经非常熟悉了,__init__ 方法通常用在初始化一个类实例的时候.例如: 1 # -*- coding: utf-8 -*- 2 3 class Person(object): 4 """Silly Person""" 5 6 def __init__(self, name, age): 7 self.na

python中的__init__ 、__new__、__call__等内置函数的剖析

1.__new__(cls, *args, **kwargs)   创建对象时调用,返回当前对象的一个实例;注意:这里的第一个参数是cls即class本身2.__init__(self, *args, **kwargs) 创建完对象后调用,对当前对象的实例的一些初始化,无返回值,即在调用__new__之后,根据返回的实例初始化:注意,这里的第一个参数是self即对象本身[注意和new的区别]3.__call__(self,  *args, **kwargs) 如果类实现了这个方法,相当于把这个类

Python中的__init__和__new__介绍

介绍 首先我们要知道在面向对象编程中,实例化基本遵循创建实例对象.初始化实例对象.最后返回实例对象这么一个过程. Python 中的 __new__ 方法负责创建一个实例对象,__init__ 方法负责将该实例对象进行初始化. __new__() 是在新式类中新出现的方法,它作用在构造方法建造实例之前,可以这么理解,在 Python 中存在于类里面的构造方法 __init__() 负责将类的实例化,而在 __init__() 启动之前,__new__() 决定是否要使用该 __init__()

python中__init__()、__new__()、__call__()几个魔法方法的用法

关于__new__()的用法参考: http://www.myhack58.com/Article/68/2014/48183.htm 正文: 一.__new__()的用法: __new__()是在新式类中新出现的方法,它作用在构造方法建造实例之前,可以这么理解,在Python 中 存在于类里面的构造方法__init__()负责将类的实例化,而在__init__()启动之前,__new__()决定是否 要使用该__init__()方法,因为__new__()可以调用其他类的构造方法或者直接返回别

python中__init__()、__new__()、__call__()、__del__()用法

http://www.myhack58.com/Article/68/2014/48183.htm 正文: 一.__new__()的用法: __new__()是在新式类中新出现的方法,它作用在构造方法建造实例之前,可以这么理解,在Python 中 存在于类里面的构造方法__init__()负责将类的实例化,而在__init__()启动之前,__new__()决定是否 要使用该__init__()方法,因为__new__()可以调用其他类的构造方法或者直接返回别的对象来作为本类 的实例. 如果将类

__init__、__new__、__call__ 方法

__init__方法 __init__方法负责对象的初始化,系统执行该方法前,其实该对象已经存在了,要不然初始化什么东西呢?先看例子: # class A(object): python2 必须显示地继承objectclass A:    def __init__(self):        print("__init__ ")        super(A, self).__init__()    def __new__(cls):        print("__new_

Python中__init__和__new__的区别详解

__init__ 方法是什么? 使用Python写过面向对象的代码的同学,可能对 __init__ 方法已经非常熟悉了,__init__ 方法通常用在初始化一个类实例的时候.例如: # -*- coding: utf-8 -*- class Person(object): """Silly Person""" def __init__(self, name, age): self.name = name self.age = age def __

Python构造器及析构器:__init__与__new__及__del__

__init__与__new__这两个魔法方法组成了Python类对象的构造器,在Python类实例化时,其实最先调用的不是__init__而是__new__.__new__是负责实例化对象的,而__init__是初始化操作.__del__是析构器,当Python对象的所有引用都不存在了(被del了),就会自动触发__del__执行. class CapStr(str): def __new__(cls, string): #此时string = 'i love you' cls是CapStr这