先来个摘要:
实例方法与类方法都要受限于那个__inin__即类的唯一构造函数??但是静态方法不用
通过设置多个类方法类实现类似多个构造函数的效果,但是实际上也受限于__inin__里面设置的需要传入参数的个数!须一样!
命名规则
class MyClass:
def method(self):
return 'instance method called', self
@classmethod
def classmethod(cls):
return 'class method called', cls
@staticmethod
def staticmethod():
return 'static method called'
以下是我对类方法实现多个构造函数的理解!
类方法
class LPL:
def __init__(self, tes):
#这个地方设定的只包含一个属性:tes
self.tes = tes
# 类方法的返回值也只能返回一个对象(因为上面self那里也只有一个tes属性),这里表示[in1,in2,in3]-->tes,返回给self中得那个tes
#通过设定类方法中的返回的in1,in2...的数量不同来新建(初始化)不同的LPL对象
#↓ 新建一个只有三个人的咱队
@classmethod
def three_tex(cls,in1,in2,in3):
return cls([in1, in2,in3])
#↓新建一个满编五人的战队
@classmethod
def five_tes(cls,in1,in2,in3,in4,in5):
return cls([in1,in2,in3,in4,in5])
#无论我们选择3人的还是5人的战队,都会打包成了一个返回给了tes
#利用调用不同的类方法来新建不同人数的战队(指的是tes),从而实现类似多个构造函数的感觉
five=LPL.five_tes('jkl','369','卡萨','左手','预言家')
three=LPL.three_tex('jkl','369','左手')
实例方法
实例方法嘛,我理解的就是只能通过一个实例化的对象来调用,否则用不了????
class LPL:
def __init__(self, tes):
#这个地方设定的只包含一个属性:tes
self.tes = tes
# 类方法的返回值也只能返回一个对象(因为上面self那里也只有一个tes属性),这里表示[in1,in2,in3]-->tes,返回给self中得那个tes
#通过设定类方法中的返回的in1,in2...的数量不同来新建(初始化)不同的LPL对象
#↓ 新建一个只有三个人的咱队
@classmethod
def three_tex(cls,in1,in2,in3):
return cls([in1, in2,in3])
#↓新建一个满编五人的战队
@classmethod
def five_tes(cls,in1,in2,in3,in4,in5):
return cls([in1,in2,in3,in4,in5])
#下面这个是不是不行?不能修改初始化后的属性?
def tex_3(self):
print(self.tes)
#无论我们选择3人的还是5人的战队,都会打包成了一个返回给了tes
#利用调用不同的类方法来新建不同人数的战队(指的是tes),从而实现类似多个构造函数的感觉
five=LPL.five_tes('jkl','369','卡萨','左手','预言家')#新建一个五人战队
three=LPL.three_tex('jkl','369','左手')#新建一个3人战队
three2=LPL(['卡萨','左手','预言家'])#通过这个来新建一个3人战队,但是没上面两个严谨,可以随意的新建含有n个人的战队
print(five.tes)
print(three.tes)
print(three2.tes)
print('###############################################')
LPL.tex_3(three2)#通过这种方法调用tex_3,必须要导入一个已经
three2.tex_3()#或者直接通过调用实例化后的LPL(three2)3
静态方法
我的理解就是一个万金油的方法,可以随意调用,无需在意它所在类中的那个构造函数是个啥,可以随意设置传入参数的数量啥的!它只是存在那个类中,但是与类无关,它之所以在那个类里面是因为一个小小的方法,必须要找一个容器,不然不好找!