类方法
是类对象 所拥有, 的方法, 需要用 修饰器, @ classmethod 来标识 其为, 类方法, 对于类方法, 第一个参数必须是类对象, 一般以 cls 作为第一个参数 ,(当然可以用其他名称的变量作为其第一个参数,但是大部分人都习惯以"cls"作为第一个参数的名字,就最好用**“cls”**了), 能够通过实例对象和类对象去访问
class People(object):
coountry = "China"
# 类方法, 用classmethod 来进行修饰
@classmethod
def get_contry(cls):
return cls.country
P = People()
print(p.get_country()) # 可以通过实例对象引用
print(People.get_country()) # 可以通过类对象的引用
类方法还有一个用途就是可以对类属性进行修改:
class People(object):
country = 'china'
#类方法,用classmethod来进行修饰
@classmethod
def get_country(cls):
return cls.country
def set_country(cls,country):
cls.country = country
p = People()
print(p.get_country()) #可以用过实例对象访问
print(People.get_country()) #可以通过类访问
p.set_country('japan')
print(p.get_country())
print(People.get_country())
结果显示在用类方法对类属性修改之后,通过类对象和实例对象访问都发生了改变
静态方法
需要通过修饰器 @staticmethod 来进行修饰, 静态方法不需要多定义参数, 可以通过对象和类来访问.
class People(object):
country = "China"
@staticmethod
# 静态方法
def get_country():
return People.conury
p = People()
# 通过对象访问静态方法
p.get_contry()
# 通过类访问静态方法
print(People.get_country())
总结
- 从类方法和实例方法以及静态方法的定义形式就可以看出来,类方法的第一个参数是类对象cls,那么通过cls引用的必定是类对象的属性和方法;
- 实例方法的第一个参数是实例对象self,那么通过self引用的可能是类属性、也有可能是实例属性(这个需要具体分析),不过在存在相同名称的类属性和实例属性的情况下,实例属性优先级更高。
- 静态方法中不需要额外定义参数,因此在静态方法中引用类属性的话,必须通过类实例对象来引用
__new__方法
new 和__init__ 的作用
class A(object):
def __init__(self):
print("这是init方法")
def __new__(self):
print("这是new方法")
return object.__new__(cls)
a = A() # "这是new方法"
# "这是init方法"
总结
- new 至少要有一个参数cls, 代表要实例化的类, 此参数在实例化时由Python解释器自动提供
- new 必须要有返回值,返回实例化出来的实例,这点在自己实现__new__ 时要特别注意,可以return父类__new__ 出来的实例,或者直接是object的 new 出来的实例
- init__有一个参数self. 就是__new__返回的实例, init 在__new 的基础上可以完成一些其它初始化的动作, init 不需要返回值
- 我们可以将类比作制造商, __new__方法就是前期的原材料购买环节, __init__方法就是在有原材料的基础上,加工,初始化商品环节
注意点
new方法必须返回正确的对象 否则init方法不执行
单例对象
# 单例
class huangD(object):
# 类属性
instance = None
# 实例属性
def __init__(slef, name):
self,name = name
def __new__(cls, *args, **kwargs):
if not cls.instance:
cls.instance = object.__nwe__(cls)
return cls.instance
Kuanxi01 = HuangD("康熙")
Kuanxi02 = HuangD("康熙")
Kuanxi03 = HuangD("康熙")
print(id(Kuangxi01))
print(id(Kuangxi02))
print(id(Kuangxi03))
# 运行结果 1794349590512
# 1794349590512
# 1794349590512