静态方法定义在类的内部函数,此函数的作用域是类的内部
静态方法需要使用@staticmethod装饰器定义
静态方法与普通函数定义相同,不需要传入self实例参数和cls类参数
静态方法只能凭借该类或类创建的实例调用
静态方法不能访问类变量和属性
list01 = [
["00", "01", "02", "03"],
["10", "11", "12", "13"],
["20", "21", "22", "23"],
]
class Vector2:
"""
二维向量
可以表示位置/方向
"""
def __init__(self, x, y):
self.x = x
self.y = y
# 静态方法:表示左边方向
@staticmethod
def left():
return Vector2(0, -1)
@staticmethod
# 静态方法:表示右边方向
def right():
return Vector2(0, 1)
# 作用:位置 + 方向
pos01 = Vector2(1, 2)
# 通过类名调用静态方法
l01 = Vector2.left()
pos01.x += l01.x
pos01.y += l01.y
print(pos01.x, pos01.y)
说白了,把定义的方法移动到类中,加个@staticmethod,这个静态方法就是将那些定义的实例化对象给使用了,那么他就成了个方法,要紧靠着我们python 是面向对象的中心思想
下面的这套代码更实战和上面的代码进行结合运行
class DoubleListHelper:
# 在二维列表中获取指定位置,指定方向,指定数量的元素.
# 例如:list01 "10" 右边 3 --> "11", "12", "13"
# 例如:list01 Vector2(1, 0) Vector2.right() 3 --> "11", "12", "13"
@staticmethod
def get_elements(target, vect_pos, vect_dir, count):
"""
在二维列表中获取指定位置,指定方向,指定数量的元素.
:param target: 二维列表
:param vect_pos: 指定位置
:param vect_dir: 指定方向
:param count: 指定数量
:return: 列表
"""
list_result = []
for i in range(count):
vect_pos.x += vect_dir.x
vect_pos.y += vect_dir.y
element = target[vect_pos.x][vect_pos.y]
list_result.append(element)
return list_result
re = DoubleListHelper.get_elements(list01, Vector2(1, 0), Vector2.right(), 3)
print(re)
# 例如:list01 "23" 左边 2
re = DoubleListHelper.get_elements(list01, Vector2(2, 3), Vector2.left(), 2)
print(re)