【问题标题】:Python's Class Variables and InheritancePython 类变量和继承
【发布时间】:2025-12-15 03:15:01
【问题描述】:

我这里有一些用于单位转换程序的代码;由于 Python 的继承顺序,它会抛出 NameError

class _Units :
    _metric_unit_names   = {'metric'}
    _standard_unit_names = {'standard'}

class TemperatureUnits (_Units) :
    _metric_unit_names.update({'celsius', 'c'})
    _standard_unit_names.update({'fahrenheit', 'f'})

TemperatureUnits()

我想知道这种情况下的“最佳”技术是什么。我可以创建_metric_unit_names_standard_unit_names 实例变量,但是在每个实例化上创建一个新集合似乎很浪费。在这种特殊情况下,共享行为似乎也是最佳选择。

【问题讨论】:

  • 当同一个类的多个实例可能就足够了时,是什么让你相信你需要多个类甚至继承?子类中是否存在您未在此处显示的某些行为?

标签: python design-patterns inheritance class-variables


【解决方案1】:

最好的做法是不要将属性定义为类的静态属性。你所追求的是这样的:

class _Units :
    def __init__(self):
        self._metric_unit_names   = {'metric'}
        self._standard_unit_names = {'standard'}

class TemperatureUnits (_Units) :
    def __init__(self):
        _Units.__init__(self)
        self._metric_unit_names.update({'celsius', 'c'})
        self._standard_unit_names.update({'fahrenheit', 'f'})

TemperatureUnits()

__init__ 之外定义属性会使它们成为类的静态成员(即_Units._metric_unit_names)。在init 中定义它们会使它们成为类实例的属性(即my_units_instance._metric_unit_names)。

【讨论】:

  • 你错过了一些selfs