1.__new__ and __init__
这两个方法都是在实例化的时候执行,__new__ 在 __init__ 之前执行,并且
如果实例化的时候封装属性,__new__也是必须要传的,而且__new__必须有返回
值,而且这个返回值就是对象的内存空间而且会传给__init__的self参数,而且
封装的属性也会传给__init__. class A:
def __new__(cls, *args, **kwargs):
print('我执行了')
return super().__new__(cls) def __init__(self, name):
self.name = name
print('我也执行了') a = A('Tom') 结果:
我执行了
我也执行了 单例模式:
class A:
__INS = None def __new__(cls, *args, **kwargs):
if not cls.__INS:
cls.__INS = super().__new__(cls)
return cls.__INS a0 = A()
a1 = A()
a2 = A()
print(a0)
print(a1)
print(a2) 结果:
<__main__.A object at 0x105e93518>
<__main__.A object at 0x105e93518>
<__main__.A object at 0x105e93518> 2. __hash__ 当调用hash函数,字典的快速查询 创建字典,集合的时候自动调用,为什么字典和集合的创建会调用?
那是因为字典和集合的创建是根据hash函数直接生成哈希值存储的,查询的时候是特别快的。必须有返回值,且为整数。 class A:
def __hash__(self):
print('我执行了')
return 1 a0 = A()
hash(a0)
dic = {a0: ''}
s = {a0} 结果:
我执行了
我执行了
我执行了 3.item系列 和 obj使用[]访问值有关系 __getitem__ obj[key] / obj[start:end] 自动执行
__setitem__ obj[key] = value 赋值的时候自动执行
__delitem__ del obj[key] del 的时候执行 class A:
def __getitem__(self, item):
return getattr(self, item) def __setitem__(self, key, value):
return setattr(self, key, value) def __delitem__(self, key):
return delattr(self, key) a = A() a['k'] = 'v' # __setitem__
print(a['k']) # __getitem__
print(a.__dict__)
del a['k'] # __delitem__
print(a.__dict__) 4.__call__ obj() 和 类()() 自动执行 class A:
def __call__(self, *args, **kwargs):
print('我执行了') a = A() A()()
a() 结果:
我执行了
我执行了 5.__len__ 该方法是对象在调用 len() 这个内置函数的时候自动触发。必须有返回值,且为整数类型 class A:
def __len__(self):
print('我执行了')
return 1 a = A()
len(a) 结果:
我执行了 6. __eq__ 当执行 == 这个魔法糖时自动执行 __eq__ 方法 ,必须有返回值,且为bool class A:
def __init__(self, name, age):
self.name = name
self.age = age def __eq__(self, other):
return True if self.name == other.name and self.age == other.age else False a0 = A('W', 18)
a1 = A('W', 18)
a2 = A('W', 18)
a3 = A('W', 18) a4 = A('W', 18) a5 = A('W', 18)
a6 = A('W', 18)
print(a0, a1)
print(a0 == a1)
print(a3 == a0 == a4) # ==这个语法 是完全和__eq__ 结果:
<__main__.A object at 0x109422438> <__main__.A object at 0x1094224e0>
True
True 7. __str__ and __repr__ # __str__ : str(obj),要求必须实现了__str__,要求这个方法的返回值必须是字符串str类型
# print(obj) '%s'%s(obj) str(obj) 这三种情况会自动触发 # __repr__: 是__str__的备胎.如果有__str__方法,那么
# print %s str都先去执行__str__方法,并且使用__str__的返回值
# 如果没有__str__,那么 print %s str都会执行repr
# repr(obj),%r # 在子类中使用__str__,先找子类的__str__,没有的话要向上找,只要父类不是object,就执行父类的__str__
# 但是如果出了object之外的父类都没有__str__方法,就执行子类的__repr__方法,如果子类也没有,
# 还要向上继续找父类中的__repr__方法.
# 一直找不到 再执行object类中的__str__方法 8. __del__ del obj 和 垃圾回收机制回收这个对象所占内存的时候。
比如就是某对象借用了操作系统的资源,还要通过析构方法归还回去这时会自动调用:文件资源,网络资源
class A:
def __del__(self):
# 析构方法 del A的对象 会自动触发这个方法
print('执行我了') a = A()
del a # 对象的删除 del 结果:
我执行了
如果不用del obj 也会执行,因为程序运行完垃圾回收会回收a这时还会执行__del__方法。

Python面向对象之魔法方法/双下方法的更多相关文章

  1. python之序列化模块、双下方法(dict call new del len eq hash)和单例模式

    摘要:__new__ __del__ __call__ __len__ __eq__ __hash__ import json 序列化模块 import pickle 序列化模块 补充: 现在我们都应 ...

  2. Python面向对象之反射,双下方法

    一. 反射 反射的概念是由Smith在1982年首次提出的,主要是指程序可以访问.检测和修改它本身状态或行为的一种能力(自省).这一概念的提出很快引发了计算机科学领域关于应用反射性的研究.它首先被程序 ...

  3. Python面向对象 | 双下方法

    定义:双下方法是特殊方法,他是解释器提供的.由双下划线+方法名+双下划线 .它具有特殊意义的方法,双下方法主要是python源码程序员使用的,我们在开发中尽量不要使用双下方法,但是深入研究双下方法,更 ...

  4. Python反射和内置方法(双下方法)

    Python反射和内置方法(双下方法) 一.反射 什么是反射 反射的概念是由Smith在1982年首次提出的,主要是指程序可以访问.检测和修改它本身状态或行为的一种能力(自省).这一概念的提出很快引发 ...

  5. python之路-双下方法

    双下方法 定义: 双下方法是特殊方法,他是解释器提供的,由双下线加方法名加双下划线 __方法名__具有特殊意义的方法 双下方法主要是Python源码程序员使用的,元编程 我们在开发中尽量不要使用双下方 ...

  6. Python 入门 之 双下方法

    Python 入门 之 双下方法 1.双下方法 ​ 定义:双下方法是特殊方法,它是解释器提供的 由双下划线加方法名加双下划线 方法名的具有特殊意义的方法,双下方法主要是python源码程序员使用的,我 ...

  7. 百万年薪python之路 -- 面向对象之 反射,双下方法

    面向对象之 反射,双下方法 1. 反射 计算机科学领域主要是指程序可以访问.检测和修改它本身状态或行为的一种能力(自省) python面向对象中的反射:通过字符串的形式操作对象相关的属性.python ...

  8. Python面向对象06 /元类type、反射、函数与类的区别、特殊的双下方法

    Python面向对象06 /元类type.反射.函数与类的区别.特殊的双下方法 目录 Python面向对象06 /元类type.反射.函数与类的区别.特殊的双下方法 1. 元类type 2. 反射 3 ...

  9. python 面向对象专题(六):元类type、反射、函数与类的区别、特殊的双下方法

    目录 Python面向对象06 /元类type.反射.函数与类的区别.特殊的双下方法 1. 元类type 2. 反射 3. 函数与类的区别 4. 特殊的双下方法 1. 元类type type:获取对象 ...

随机推荐

  1. 灰色大气企业html5模板

    灰色大气企业html网页模板是一款以灰色为背景的大气简洁企业html5网站模板. 下载地址:http://www.huiyi8.com/sc/10860.html

  2. CentOS7 默认防火墙firewalld

    firewalld基础 firewalld是CentOS7源生支持的防火墙,firewalld最大的好处有两个:支持动态更新,不用重启服务:第二个就是加入了防火墙的“zone”概念. firewall ...

  3. Java的访问权限修饰符

    default或者friendly表示默认的访问权限修饰符.

  4. win32com操作word(3):导入VBA常量

    导入VBA常量方法:http://blog.sina.com.cn/s/blog_a73687bc0101k8x8.html 我们之前说过,win32com组件为python提供处理COM组件(.dl ...

  5. BZOJ-3881:Divljak (AC自动机+DFS序+树链求并+树状数组)

    Alice有n个字符串S_1,S_2...S_n,Bob有一个字符串集合T,一开始集合是空的. 接下来会发生q个操作,操作有两种形式: “1 P”,Bob往自己的集合里添加了一个字符串P. “2 x” ...

  6. 2084. Asm.Def的基本算法

    2084. Asm.Def的基本算法 传送门 ★☆   输入文件:asm_algo.in   输出文件:asm_algo.out   简单对比时间限制:1 s   内存限制:256 MB [题目描述] ...

  7. [转]深入了解 CSS3 新特性

    简介 CSS 即层叠样式表(Cascading Stylesheet).Web 开发中采用 CSS 技术,可以有效地控制页面的布局.字体.颜色.背景和其它效果.只需要一些简单的修改,就可以改变网页的外 ...

  8. UVA 10559 Blocks——区间dp

    题目:https://www.luogu.org/problemnew/show/UVA10559 应该想到区间dp.但怎么设计状态? 因为连续的东西有分值,所以应该记录一下连续的有多少个. 只要记录 ...

  9. poj1456Supermarket——并查集压缩查找

    题目:http://poj.org/problem?id=1456 排序+贪心,每次选利润最大的,放在可能的最靠后的日期卖出,利用并查集快速找到下一个符合的日期. 代码如下: #include< ...

  10. exosip 和 pjsip 简介

     oSIP oSIP的开发开始于2000年7月,第一个版本在2001年5月发 布,到现在已经发展到3.x了.它采用ANSI C编写,而且结 构简单小巧,所以速度特别快,它并不提供高层的SIP会话 控制 ...