1、def __add__(self,other):
c1+c2 两个实例的加法操作就是执行__add__()方法
2、__str__(self):
print一个实例的时候,执行的是__str__()这个内置方法
eg:
class Vector(object):
     def __init__(self,a,b):
         self.a = a
         self.b = b
     def __str__(self):
         return 'Vector(%d,%d)'%(self.a,self.b)
     def __add__(self, other):
          return Vector(self.a+other.a, self.b+other.b)
 
v1 = Vector(2,8)
v2 = Vector(4,98)
# print v1 + v2
v3 = v1 + v2
print v3
print v1#
 
3、__del__()
实例消亡的时候执行
4、类的帮助信息 三引号中的内容
__doc__
''' Production of the class A
attr:
method:
'''
5、类的实例属性是字典的时候,使用以下三个方法
__getitem__() :返回当前的实例属性的字典值
__setitem__():属性中的key和value重新赋值
__delitem__():删除实例属性中的某个字典key和value值
 
class A(object):
'''Production of the class A:
attr:
 
method:
end.'''
#__getitem__
#__setitem__
#__delitem__
class Employee(object):
    def __init__(self,name,salary):
        self.dict1={}
        self.dict1[name]=salary
    def __getitem__(self, key):
         if self.dict1.has_key(key):
             print key,self.dict1[key]
    def __setitem__(self, key, value):
         self.dict1[key]=value
    def __delitem__(self, key):
         if self.dict1.has_key(key):
    del self.dict1[key]
 
e1=Employee('Lily',10000)
e1['Lily']
e1['Jenny']=20000
e1['Jenny']
del e1['Jenny']
e1['Jenny']
 
6、实例属性是序列的时候,所作的切片操作
__getslice__():对实例属性做切片
__setslice__():
__delslice__():
 
7、__call__(self,*args,**kwargs)
通过实例对__call__方法重写 e1(1,2,3,a='abc')
 
8、__dict__ 返回属性和方法
Employee.__dict__ :类属性和所有的方法
e.__dict__ 实例属性和类的指针
 
9、__iter__() 使用迭代器,返回迭代器的内容时,就是调用了__iter__方法,返回一个迭代器
def __iter__(self):
    return iter(self.list1[:])
eg:
class Employee(object):
    def __init__(self,name,salary):
        self.list1=[]
    def __getslice__(self,i,j):
        return self.list1[i:j]
    def __setslice__(self, i, j, sequence):
         self.list1[i:j]=sequence
    def __delslice__(self, i, j):
          del self.list1[i,j]
    def __iter__(self):
         return iter(self.list1[:])
 
e1=Employee('Lily',10000)
e1[:4]='fjwioefjior'
print e1[:]
for i in e1:
    print i
10、__new__(cls,*args,**kwargs):
new的时候才生成了实例,所以是类方法
return object.__new__(cls,*args,**kwargs)
a=A() 这个时候会默认先执行__new__这个内置方法
使用在单例(只有一个实例)这种设计模式中:
通过 __new__方法实现单例的思路:创建实例之前,判断是否创建过,如果有,不重新创建,没有则重新创建
#__new__
class A(object):
    def __init__(self,a):
        print 'init method'
       self.a = a
   def __new__(cls, *args, **kwargs):
        if not hasattr(cls,'_instance'):
            cls._instance = object.__new__(cls,*args, **kwargs)
   return cls._instance
 
之前是否创建过实例,如果有,则不重新创建,如果没有,则重新创建
a1 = A(4)
print a1.a # 4
a2 = A(6)
print a2.a # 6
print a1.a # 6
实例属性是同一个,但是每次实例化的时候,还会再执行__init__()方法
 

Python之面向对象:类的内置方法的更多相关文章

  1. Python进阶-XVIV 类的内置方法:__str__ 、__repr__、析构函数(__del__)、双下的call,eq,new,hash 以及item相关的三个方法

    类的内置方法 它与内置函数有紧密的联系,有的内置函数就是调用的内置方法. 在顶级父类obj中有: 两个双下方法 obj.__str__ str(obj) obj.__repr__ repr(obj) ...

  2. python 面向对象 类的内置方法

    判断是不是类cls的对象 class A: pass a = A() print(isinstance(a,A)) 判断类sub是不是super的子类 class A: pass class B(A) ...

  3. python面向对象--类的内置方法

    #isinstance(obj,cls)判断obj是否是类cls的实例 #issubclass(cls,cls1)判断cls是否是cls1的子类或派生类 class Foo: pass class B ...

  4. day28 面向对象:反射,内置函数,类的内置方法

    面向对象进阶博客地址链接: http://www.cnblogs.com/Eva-J/articles/7351812.html 复习昨日内容: # 包 # 开发规范 # # hashlib # 登录 ...

  5. 二十六. Python基础(26)--类的内置特殊属性和方法

    二十六. Python基础(26)--类的内置特殊属性和方法 ● 知识框架 ● 类的内置方法/魔法方法案例1: 单例设计模式 # 类的魔法方法 # 案例1: 单例设计模式 class Teacher: ...

  6. python学习之老男孩python全栈第九期_day027知识点总结——反射、类的内置方法

    一. 反射 ''' # isinstance class A:pass class B(A):pass a = A() print(isinstance(a,A)) # 判断对象和类的关系 print ...

  7. python基础语法18 类的内置方法(魔法方法),单例模式

    类的内置方法(魔法方法): 凡是在类内部定义,以__开头__结尾的方法,都是类的内置方法,也称之为魔法方法. 类的内置方法,会在某种条件满足下自动触发. 内置方法如下: __new__: 在__ini ...

  8. python -- 类中--内置方法

    isinstance 和  issubclass isinstance(obj,b)  检查是否obj是否是类b的对象 class A(object):pass class B(A):pass b=B ...

  9. 第8.14节 Python类中内置方法__str__详解

    一. object类内置方法__str__和函数str 类的内置方法__str__和内置函数str实际上实现的是同一功能,实际上str调用的就是__str__方法,只是调用方式不同,二者的调用语法如下 ...

  10. 第8.13节 Python类中内置方法__repr__详解

    当我们在交互环境下输入对象时会直接显示对象的信息,交互环境下输入print(对象)或代码中print(对象)也会输出对象的信息,这些输出信息与两个内置方法:__str__方法和__repr__方法有关 ...

随机推荐

  1. 记一次samba排错 Failed to start Samba SMB Daemon.

       记录一次服务出错排错的过程,很多新手出了点错不百度直接巴拉巴拉的问,一般老手根据经验可以给出一点建议,但是由于个体环境的差异并不适用,反而埋怨起来.这种真的无F**K可说,所以要培养自己的排错能 ...

  2. 一个简单的WPF MVVM实例【转载】

    引用地址:http://blog.csdn.net/yl2isoft/article/details/20838149 1 新建WPF 应用程序WPFMVVMExample 程序结构如下图所示. 2  ...

  3. 搭建一个简单的dns缓存服务器

    环境:linux 软件:bind97,bind97-utils, bind97-libs ip:192.168.192.130:192.168.192.131 -------------------- ...

  4. C语言基础篇(三) 指针

    导航: 1.指针     2. 数组     3. 结构体,共用体     4. 内存分布图     5. 段错误分析 ----->x<------------->x<---- ...

  5. 001---web应用程序

    什么是web应用? 应用程序分两种模式:C/S.B/S 1 .C/S:客户端(Client)与服务端 一般独立运行 2 .B/S:浏览器(Browser)与服务端 这类应用要借助浏览器:谷歌.火狐.I ...

  6. redhat 配置本地yum源

    redhat配置3个源就够了: 1.本地yum源,就是你本地的ISO 2.配置163源 3.配置epel源 环境:redhat7 + vmw 12 pro 1.配置本地yum源 要配置本地源,需要先把 ...

  7. 笔记-爬虫-selenium常用方法

    笔记-爬虫-selenium常用方法 1.      查找元素 常用的查找方法 find_element_by_name find_element_by_xpath find_element_by_l ...

  8. Hibernate---架构

    Hibernate 架构是分层的,作为数据访问层,你不必知道底层 API .Hibernate 利用数据库以及配置数据来为应用程序提供持续性服务(以及持续性对象). 下面是一个非常高水平的 Hiber ...

  9. python 三目运算

    python中的三目运算: result = a if condition else b #当满足condition返回a否则返回b 三目运算可以使你的代码看起来简洁,且运算高效

  10. Fiddler - 使用教程

    1.断点调试,修改请求表单和响应数据 命令介绍: bpu在请求开始时中断,bpafter在响应到达时中断,bps在特定http状态码时中断,bpv/bpm在特定请求method时中断. bpu m.t ...