Python 其实不是面向对象的语言,更像是C语言的面向过程编程的语言
但 Python 也支持 class 关键字来实现类的声明与创建
但 Python 的对象更像是 JavaScript 的函数
遇到的问题 #1
-- 正确的代码
class Person: user_account = None name = None days = None months = None abnormal_days = 0 total_hours = 0 total_work_overtime = 0 total_late_hours = 0 def __init__(self, user_acount, name): self.user_account = user_acount self.name = name self.days = [] self.months = [] # 增加12个月的month_record 对象 for i in range(1, 13): self.months.append(date_process.MonthRecord(i)) print(len(self.months))
-- 错误的代码
class Person: user_account = None name = None days = None months = [] abnormal_days = 0 total_hours = 0 total_work_overtime = 0 total_late_hours = 0 def __init__(self, user_acount, name): self.user_account = user_acount self.name = name self.days = [] # 增加12个月的month_record 对象 for i in range(1, 13): self.months.append(date_process.MonthRecord(i)) print(len(self.months))
这两段代码的查询在于 months 变量,在正确的代码里,成员变量的定义里写成了 months = None, months = [ ] 写在了 __init__() 函数里面, 而在错误的代码里写成了 months = [ ]。错误的代码产生的影响是什么呢?
-----------
当你创建一个新的 Person 对象 first_person 时候,在开始执行 __init__() 函数的时候(即是运行到
self.user_account = user_acount
这一步的时候),months 的对象是 [ ]
当你创建第二个 Person 对象 secong_person 的时候,第二次执行 __init__() 函数的时候,months 的对象是 first_person.month(),其引用的其实同一块内存区域的值。
这个地方非常的反直觉,造成的后果也非常大,我为了排查这个错误也花了很久的时间。
--------- 一点猜测
只是猜测而已,没有进行过详细的验证
pyhthon 的 class 其实只是一个类似JS的函数对象,这个函数有自己的内存空间,但是实际上类就像一个函数,每一次引用的的时候都是调取的同一块内存区域,所以,Python写类的时候,成员变量的初始化请务必写到 __init__()函数里
---------- 验证图片
first_person:
second_person: