Python3学习之路~6.3 类变量 VS 实例变量

类变量 VS 实例变量

#Author:Zheng Na

# 实例里面可以查询、增加、删除、修改实例变量

class Role: # 类名
    # 类变量
    name = '我是类name'
    n=1
    n_list=[]
    def __init__(self,name,role,weapon,life_value=100,money=15000):
        # 构造函数
        # 在实例化时做一些类的初始化的工作
        # 开辟一块内存,将下面这些变量传进去
        self.name = name # 实例变量(静态属性),作用域就是实例本身(r1和r2的实例变量不能共享)
        self.role = role
        self.weapon = weapon
        self.life_value = life_value
        self.money = money

    def buy_gun(self,gun_name): # 类的方法(动态属性)
        print("%s just bought %s" %(self.name,gun_name))

    def got_shot(self):
        print("ah...I got shot...")

print(Role.n) #1 在没有实例化之前,就可以打印类变量,说明类变量存放在类的内存里

r1 = Role("Alex","Policeman","AK47") # 生成一个角色,把一个类变成一个具体对象的过程叫实例化
r2 = Role("Jack","terrorist",'B22')

r1.buy_gun("AK47") #Alex just bought AK47
r1.got_shot() #ah...I got shot...

# 通过实例调用一个变量时,先在实例中寻找这个变量,如果找不到,再去类中寻找
print(r1.n) #1 实例化之后,通过实例对象也可以调用类变量(先去实例中寻找变量n,找不到,再去类中寻找,找到了!)
print(r1.name) #Alex 当实例变量与类变量同名时,先去找实例变量,再去找类变量

r1.name ='Rose' #实例化后再修改变量值,修改了实例变量
print(r1.name) #Rose
print(Role.name) #我是类name

r1.bullet_prove = True # 实例化后可以再增加一个属性,仅给r1增加了属性,r2没有这个属性
print(r1.bullet_prove) # True

# print(r1.weapon) # AK47
del r1.weapon # 可以删除属性
# print(r1.weapon) # 报错

r1.n="改类变量" # r1改了类变量,r2没改,内部实际上是在r1的内存里创建了一个新的变量,实际上不影响类变量本身
print(r1.n) # 改类变量
print(r2.n) # 1
print(Role.n) # 1

# 在类中修改变量,效果就是在类内存中存放的类变量由n=1变为n='ABC'
# 在实例r1调用变量n时,先在r1内存中寻找n,找到了,返回其值“改类变量”
# 在实例r2调用变量n时,先在r2内存中寻找n,没找到,再去类的内存中寻找n,此时类变量n的值已修改,于是返回修改后的值。
Role.n="ABC" #在类中修改变量
print(r1.n)  # 改类变量
print(r2.n)  # ABC

# 当类变量为list时,无论实例r1或r2修改其值,改变的都是类变量的值,因为他们用的是同一个内存变量
r1.n_list.append("from r1")
r2.n_list.append("from r2")
print(Role.n_list) # ['from r1', 'from r2']
print(r1.n_list)   # ['from r1', 'from r2']
print(r2.n_list)   # ['from r1', 'from r2']

类变量的作用

类变量的作用就是保存大家共用的属性,节省开销(省内存)。
比如某一个系统中的所有用户均是中国人,那么国籍这个变量就可以写为类变量。
如下代码中的2个Person类所示,虽然最终结果时一样的,但是使用Person1类时,每实例化一个对象,就会开辟一块内存,传一个默认参数cn进去。中国有14亿人口,就会存14亿个参数,浪费内存。使用Person2类时,类变量cn仅存在于类的内存空间中,所有的实例均调用这个变量,节省开销。

#Author:Zheng Na

class Person1:
    def __init__(self,name,age,addr,cn="china"): #默认参数
        self.name = name
        self.age = age
        self.addr = addr
        self.cn = cn

class Person2:
    cn='china' #类变量
    def __init__(self,name,age,addr):
        self.name = name
        self.age = age
        self.addr = addr

p1 = Person1("xiaoming",21,"山东")
print(p1.cn) # china

p2 = Person2("xiaoming",21,"山东")
print(p2.cn) # china

  

 

猜你喜欢

转载自www.cnblogs.com/zhengna/p/9598694.html