本节内容:
经典类vs新式类
静态方法、类方法、属性方法
类的特殊方法
反射
面向对象高级语法部分
把下面代码用python2 和python3都执行一下
class A: def __init__(self): self.n = ‘A‘ class B(A): # def __init__(self): # self.n = ‘B‘ pass class C(A): def __init__(self): self.n = ‘C‘ class D(B,C): # def __init__(self): # self.n = ‘D‘ pass obj = D() print(obj.n)
classical vs new style:
在Python2 中,经典类是按照深度优先来继承的,新式类是按广度优先来继承的
在python3 中,经典类、新式类都是按照广度优先来继承的
静态方法
通过@staticmethod装饰器即可把其装饰的方法变为一个静态方法,什么是静态方法呢?其实不难理解,普通的方法,可以在实例化后直接调用,并且在方法里可以通过self.调用实例变量或类变量,但静态方法是不可以访问实例变量或类变量的,一个不能访问实例变量和类变量的方法,其实相当于跟类本身已经没什么关系了,它与类唯一的关联就是需要通过类名来调用这个方法
class Dog(object): def __init__(self,name): self.name = name @staticmethod #把eat方法变为静态方法 def eat(self): print("%s is eating" % self.name) d = Dog("ChenRonghua") d.eat()
上面的调用会出以下错误,说是eat需要一个self参数,但调用时却没有传递,没错,当eat变成静态方法后,再通过实例调用时就不会自动把实例本身当作一个参数传给self了。
Traceback (most recent call last): File "/Users/jieli/PycharmProjects/python基础/自动化day7面向对象高级/静态方法.py", line 17, in <module> d.eat() TypeError: eat() missing 1 required positional argument: ‘self‘
想让上面的代码可以正常工作有两种办法
1. 调用时主动传递实例本身给eat方法,即d.eat(d)
2. 在eat方法中去掉self参数,但这也意味着,在eat中不能通过self.调用实例中的其它变量了
class Dog(object): def __init__(self,name): self.name = name @staticmethod def eat(): print(" is eating") d = Dog("ChenRonghua") d.eat()
原文:http://www.cnblogs.com/Ironboy/p/7152753.html