函数部分:
注意可以传的组合参数
- 位置参数、默认参数、可变参数和关
- 位置参数、默认参数、命名关键字参数和关键字参数。
Python的魔法函数部分:
__init__(self[, param1, param2...]) 的魔法方法,该方法在类实例化时会自动调用。
私有方法为__方法名
继承:类名(父类名)
多重继承:类名(父类名1,父类名2,父类名3)
此时如果父类中有相同的方法,则使用最前面的父类1的方法
类属性一旦修改,相关实例属性会有修改,实例属性修改不会影响类属性
#创建类对象
class Test(object):
class_attr = 100 #类属性
def __init__(self):
self.sl_attr = 100 #实例属性
def func(self):
print('类对象.类属性的值:',Test.class_attr) #调用类属性
print('self.类属性的值:',self.class_attr)#相对于把类属性变成实例属性
print('self.实例属性的值:',self.sl_attr)#调用属性
a = Test()
#a.func()
#类对象.类属性的值: 100
#self.类属性的值: 100
#self.实例属性的值: 100
b = Test()
#b.func()
#类对象.类属性的值: 100
#self.类属性的值: 100
#self.实例属性的值: 100
a.class_attr = 200
a.sl_attr = 200
#a.func()
#类对象.类属性的值: 100
#self.类属性的值: 200
#self.实例属性的值: 200
#b.func()
#类对象.类属性的值: 100
#self.类属性的值: 100
#self.实例属性的值: 100
Test.class_attr = 300
#a.func()
#类对象.类属性的值: 300
#self.类属性的值: 200
#self.实例属性的值: 200
#b.func()
#类对象.类属性的值: 300
#self.类属性的值: 300
#self.实例属性的值: 100
__new__方法如果被定义,会在__init__方法之前执行
反运算符这里没太明白为什么是这个结果
定制序列:类似于其他语言的借口
如果说你希望定制的容器是不可变的话,你只需要定义__len__() 和__getitem__() 方法。
如果你希望定制的容器是可变的话,除了__len__() 和__getitem__() 方法,你还需要定义__setitem__() 和__delitem__() 两个方法。
|