我无法准确理解这段代码的用途
class buildArgs:
def __init__(self, host, port, user, dept):
self._dept = dept
self._host = host
self._port = port
self._user = user
self._datacenter = datacenter
self._path = path
def __init__(self):
self._dept = None
self._host = None
self._port = None
self._user = None
self._datacenter = None
self._path = None
接下来是一堆 @property 方法,后面是这样的 setter,然后是 main 方法:
@property
def port(self):
return self._port
@port.setter
def port(self, port):
self._port = port
我以前从未在 Python 中的一个类下见过两个 __init__ 函数,并且我认为这是非 Python 的。这种逻辑的正确方法是什么?
最佳答案
该代码的作用相当于不定义第一个 __init__
根本没有(它立即被第二个取代,并且再也没有出现过)。
您可以通过仅使用第一个构造函数并为所有参数指定默认值 None
来获得与这两种行为类似的结果。 :
def __init__(self, host=None, port=None, user=None, dept=None):
self._dept = dept
self._host = host
self._port = port
self._user = user
这也允许提供一些参数,但不是全部。对于更复杂的情况,将备用构造函数定义为 @classmethod
(类方法的存在主要是为了实现备用构造函数),它将自己的参数转换(或提供)为主构造函数所期望的参数,然后以 return cls(expected, arguments, here)
结尾:
class buildArgs:
def __init__(self, host, port, user, dept):
self._dept = dept
self._host = host
self._port = port
self._user = user
@classmethod
def from_the_void(cls):
return cls(None, None, None, None)
关于python - Python中重载构造函数的要点?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59887423/