3 回答
TA贡献1757条经验 获得超8个赞
如果你只有一个实例,那么最好每个实例创建所有变量,只是因为它们会被访问(一点点)更快(由于从类到实例的“继承”,一个更少的“查找”级别),并且没有任何缺点可以衡量这个小优势。
TA贡献1752条经验 获得超4个赞
进一步回应迈克和亚历克斯的建议并添加我自己的颜色......
使用实例属性是典型的,更惯用的Python。类属性不常使用 - 至少在我连续13年的Python中没有生产代码。对于静态和类方法也是如此...除非有特定的用例或异常的程序员想要炫耀他们知道Python编程的一些不起眼的角落,否则不是很常见。
alex在他的回复中提到,由于一个较少的查找级别,访问速度会快一点点...让我进一步澄清那些不知道它是如何工作的人,它与变量访问非常相似 - - 按此顺序搜索:
当地人
nonlocals
全局
内置插件
对于属性访问,顺序是:
例
类
由MRO确定的基类(方法解析顺序)
在上面的示例中,假设您正在查找path
属性。当遇到像“ self.path
” 这样的引用时,Python会首先查看实例属性以获得匹配; 当失败时,它会检查从中实例化对象的类。最后,它将搜索基类。正如亚历克斯所说,如果在实例中找到你的属性,它就不会顺从类,因此节省了一点时间。
但是,如果你坚持使用类属性,你将不得不放弃这一点性能,或者,你的另一种选择是通过类而不是实例引用对象,例如,MyController.path
而不是self.path
。这是一个直接查找,它将绕过延迟查找,但正如alex提到的那样,这是一个全局变量,所以你会丢失那个你认为要保存的位(除非你创建一个对[global]类名的本地引用)。
TA贡献1810条经验 获得超4个赞
如有疑问,您可能需要实例属性。
类属性最好保留用于有意义的特殊情况。唯一非常常见的用例是方法。对于实例需要知道的只读常量,使用类属性并不罕见(尽管这样做的唯一好处就是如果你也希望从类外部进行访问),但你应该谨慎地将任何状态存储在它们中,这很少是你想要的。即使您只有一个实例,也应该像编写其他任何实例一样编写类,这通常意味着使用实例属性。
添加回答
举报