一般来说,类中定义的所有的方法都是对象的绑定方法,对象在调用绑定方法时会自动将自己作为参数传递给方法的第一个参数。除此之外还有两种常见的方法:静态方法和类方法,二者是为类量身定制的,但是实例非要使用,也不会报错。我们这里说一下静态方法。

class C(object):
    @staticmethod
    def f():
        print('runoob');
 
C.f();          # 静态方法无需实例化
cobj = C()
cobj.f()        # 也可以实例化后调用

以上实例声明了静态方法 f,类可以不用实例化就可以调用该方法 C.f(),当然也可以实例化后调用 C().f()。

强调,注意注意注意:静态方法和类方法虽然是给类准备的,但是如果实例去用,也是可以用的,只不过实例去调用的时候容易让人混淆,不知道你要干啥

 

 

和类的普通的方法不同,staticmethod()方法不需要self这个参数

应用场景:编写类时需要采用很多不同的方式来创建实例,而我们只有一个__init__函数,此时静态方法就派上用场了。

import time
class Date:
    def __init__(self,year,month,day):
        self.year=year
        self.month=month
        self.day=day
    @staticmethod
    def now(): #用Date.now()的形式去产生实例,该实例用的是当前时间
        t=time.localtime() #获取结构化的时间格式
        return Date(t.tm_year,t.tm_mon,t.tm_mday) #新建实例并且返回
    @staticmethod
    def tomorrow():#用Date.tomorrow()的形式去产生实例,该实例用的是明天的时间
        t=time.localtime(time.time()+86400)
        return Date(t.tm_year,t.tm_mon,t.tm_mday)

a=Date('1987',11,27) #自己定义时间
b=Date.now() #采用当前时间
c=Date.tomorrow() #采用明天的时间

print(a.year,a.month,a.day)
print(b.year,b.month,b.day)
print(c.year,c.month,c.day)

结果为:

1997 11 23
2018 10 17
2018 10 18

 

 

  总结:

1.不用实例化对象,就可以直接用 C.f() 调用静态方法

2.静态方法充当构造函数的重载???用不同的方式来创建实例

 

然后我发现,总结里面的第二条,也可以用普通的类的方法来实现,代码如下:

import time
class Date:
    def __init__(self,year,month,day):
        self.year = year
        self.month = month
        self.day = day

    def now(self):
        t = time.localtime()
        return Date(t.tm_year,t.tm_mon,t.tm_mday)

    def tomorrow(self):
        t = time.localtime(time.time()+86400)
        return Date(t.tm_year,t.tm_mon,t.tm_mday)

a = Date(1997,11,23)
b = a.now()
c = a.tomorrow()

print(a.year,a.month,a.day)
print(b.year,b.month,b.day)
print(c.year,c.month,c.day)

结果同样为:

1997 11 23
2018 10 17
2018 10 18

这个方法相当于先创建一个对象,然后用这个对象调用方法,该方法返回一个新的对象,把对象赋值给b和c。

此时now(self)和tomorrow(self)相当于一个普通的类的方法,而不是静态方法了。