当一个类需要创建大量实例时,可以通过__slots__声明实例所需要的属性, 优点: 1)更快的属性访问速度 2)减少内存消耗 3)限定一个类创建的实例只能有固定的实例属性(实例变量),不允许对象添加列表以外的实例属性 4)防止用户因错写属性名称而发生程序错误 缺点: 1)每个继承的子类都要重新定义一遍__slots__ 实例只能包含哪些在__slots__定义的属性,这对写程序的灵活性有影响,比如你由于某个原因新网给instance设置一个新的属性,比如instance.a = 1, 但是由于…
http://blog.csdn.net/pipisorry/article/details/50708616 Python 中的 property 属性 Python中有个很赞的概念,叫做property,它使得面向对象的编程更加简单. property使用实例 假设有天你决定创建一个类,用来存储摄氏温度.当然这个类也需要实现一个将摄氏温度转换为华氏温度的方法.一种实现的方式如下: class Celsius:     def __init__(self, temperature = 0):…
#类的属性 class A(): #定义一个类的属性,类似于c++中的静态变量 num=0 def __init__(self): #实例对象属性定义赋值 self.name = "hha" def add(self): #类属性的调用 A.num += 1 a = A() a.add() a.add() print(A.num) #类中的方法 class Dog(): #系统默认实例方法 def __init__(self): self.name = "tom"…
#定义一下类, 含有类属性 aaa, >>> class Aa: ... aaa = 10... #对类 Aa实例化出一个实例 a1>>> a1 = Aa() >>> print(a1.__dict__)#查看实例并没有自己的方法和属性{}>>> a1.aaa #但是这个实例在调用属性的时候, 发现自己没有这个属性, 于是去找其类有没有这个属性, 找到了就返回类的属性10>>> print(a1.__dict__)#…
class Foo(object): def __init__(self): # 这是一个对象属性 self.obj_pro = 12 # 这是一类属性 c_pro = 11 # 这是一个静态方法 @classmethod def c_method(self): print('c_method') if __name__ == '__main__': f = Foo() """ 如何查找对象属性? 就是在对象的__dict__字典去找,对象__dict__找不到,再去类__d…
不注意点了个逗号引发了类型改变 [shangbl@newsvn ~]$ cat test.py class AB1: a="a" class AB12: a="a", print(type(AB1.a)) print(type(AB12.a)) [shangbl@newsvn ~]$ python test.py <type 'str'> <type 'tuple'>…
1.Python类数据属性:定义在类里面但在函数外面的变量,它们都是静态的. #一段很简单的代码,但反应了很多 >>> class A(): a=1 #一个类里面有个属性a >>> a=A() >>> b=A() >>> a.a 1 >>> b.a 1 >>> A.a 1 #这个属性能被实例和类访问 >>> a.a=2 >>> b.a 1 >>>…
常规情况下,类的属性字典是共享的,而实例的字典是独立的.如果一个类的属性较少,但是拥有很多的实例,这些实例的属性字典会占用较多的内存空间.对这样的类来说,为了节省内存空间,可以使用__slots__类变量代替__init__()来存储数据属性. 定义__slots__之后,系统会为实例使用一种更加紧凑的内部表示,即通过一个很小的固定大小的数组来构建,而不是为每一个实例定义一个字典. __slots__可以是列表.元组.字符串等可迭代对象 定义__slots__之后,类保留有__dict__,但实…
部分参考自:http://www.geekfan.net/7862/ 新式类与经典类 2和3不一样,3都是新式类. 新式类和经典类的区别: class A: #classic class """this is class A""" pass __slots__=('x','y') def test(self): # classic class test """this is A.test()""&…
1,私有属性 class Foo: def __init__(self, x): self.x = x 类的属性在实例化之后是可以更改的: f = Foo(1) print(f.x) # 1 f.x = 2 print(f.x) # 2 如果想禁止访问属性,即让属性私有,可以用“双下划线” 或者“单下划线”: class Foo: def __init__(self, x, y): self._x = x self.__y = y def __repr__(self): return 'f._x…