Speed up execution
`if method in dir(self):` is very inefficient: - it must construct a list object listing all the object attributes & methods - it must then perform a O(N) linear scan of that list Replace it with the idiomatic `if hasattr(self, method):`, which is a O(1) expected time hash lookup. Should fix #11981.
This commit is contained in:
parent
efa005c228
commit
44c94328c8
1 changed files with 1 additions and 1 deletions
|
@ -96,7 +96,7 @@ class Base:
|
|||
@staticmethod
|
||||
def _generic_g(prop_name, self):
|
||||
method = "_get_attr_%s" % prop_name
|
||||
if method in dir(self):
|
||||
if hasattr(self, method):
|
||||
return getattr(self, method)()
|
||||
|
||||
return self._attributes[prop_name]
|
||||
|
|
Loading…
Add table
Reference in a new issue