您的位置:首页 > 编程语言 > Python开发

Python类的实例方法、静态方法和类方法

2018-03-21 23:13 239 查看
class Foo(object):
"""类三种方法语法形式"""

def instance_method(self):
print("是类{}的实例方法,只能被实例对象调用".format(Foo))

@staticmethod
def static_method():
print("是静态方法")

@classmethod
def class_method(cls):
print("是类方法")

foo = Foo()
foo.instance_method()
foo.static_method()
foo.class_method()
print('----------------')
Foo.static_method()
Foo.class_method()


实例方法只能被实例对象调用。

静态方法(由@staticmethod装饰的方法)、类方法(由@classmethod装饰的方法),可以被类或类的实例对象调用。

实例方法,第一个参数必须要默认传实例对象,一般习惯用self。

静态方法,参数没有要求。

类方法,第一个参数必须要默认传类,一般习惯用cls。

又例如:

class Room:
tag = 1

def __init__(self, name, owner, width, length, heigh):
self.name = name
self.owner = owner
self.width = width
self.length = length
self.heigh = heigh

@property
def cal_area(self):
return self.width * self.length

def test(self):
print('from test', self.name)

@classmethod
def tell_info(cls, x):
print(cls)
print('-->>', cls.tag, x)

@staticmethod
def wash_body(a, b, c):
print('{}\n{}\n{}'.format(a, b, c))

r = Room('厕所', 'alex', 100, 100, 100000)
print(r.name)
print(r.cal_area)
r.test()

Room.tell_info(10)
Room.test(r)
print('------')
r.tell_info(20)
print('--------')
Room.wash_body('alex', 'yuanhao', 'wupeiqi')
r.wash_body('alex', 'yuanhao', 'wupeiqi')
------------------------------------------------
输出:

厕所
10000
from test 厕所
<class '__main__.Room'>
-->> 1 10
from test 厕所
------
<class '__main__.Room'>
-->> 1 20
--------
alex
yuanhao
wupeiqi
alex
yuanhao
wupeiqi


静态方法、类方法使用区别或者说使用场景

1、类方法用在模拟java定义多个构造函数的情况。

由于python类中只能有一个初始化方法,不能按照不同的情况初始化类。

参考django https://docs.djangoproject.com/en/1.9/ref/models/instances/

请看下面的代码。

# coding:utf-8

class Book(object):

def __init__(self, title):
self.title = title

@classmethod
def create(cls, title):
book = cls(title=title)
return book

book1 = Book("python")
book2 = Book.create("python and django")
print(book1.title)
print(book2.title)


特别说明,静态方法也可以实现上面功能,当静态方法每次都要写上类的名字,不方便。

2、类中静态方法方法调用静态方法的情况。

下面的代码,静态方法调用另一个静态方法,如果改用类方法调用静态方法,可以让cls代替类,

让代码看起来精简一些。也防止类名修改了,不用在类定义中修改原来的类名。

# coding:utf-8

class Foo(object):
X = 1
Y = 2

@staticmethod
def averag(*mixes):
return sum(mixes) / len(mixes)

@staticmethod
def static_method():
return Foo.averag(Foo.X, Foo.Y)

@classmethod
def class_method(cls):
return cls.averag(cls.X, cls.Y)

foo = Foo()
print(foo.static_method())
print(foo.class_method())


3、继承类中的区别

从下面代码可以看出,如果子类继承父类的方法,子类覆盖了父类的静态方法,

子类的实例继承了父类的static_method静态方法,调用该方法,还是调用的父类的方法和类属性。

子类的实例继承了父类的class_method类方法,调用该方法,调用的是子类的方法和子类的类属性。

# coding:utf-8

class Foo(object):
X = 1
Y = 2

@staticmethod
def averag(*mixes):
return sum(mixes) / len(mixes)

@staticmethod
def static_method():
return Foo.averag(Foo.X, Foo.Y)

@classmethod
def class_method(cls):
return cls.averag(cls.X, cls.Y)

class Son(Foo):
X = 3
Y = 5

@staticmethod
def averag(*mixes):
return sum(mixes) / 3

p = Son()
print(p.static_method())
print(p.class_method())
# 1.5
# 2.6666666666666665
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: