未调用__init__

问题描述

在下面的代码中,我了解了new和init之间的区别。 当我运行代码时,我收到以下错误:

错误:

cls: <class '__main__.ThreadsWithSync'>
Traceback (most recent call last):
File "m:python lessonsThreadsWithSync.py", line 37, in <module>
    ThreadsWithSync()
File "m:python lessonsThreadsWithSync.py", line 12, in __new__
    cls.onCreateObject()
File "m:python lessonsThreadsWithSync.py", line 20, in onCreateObject
    print(instance)
File "C:UsersAmr.BakriAppDataLocalProgramsPythonPython39lib	hreading.py", line 842, in __repr__
assert self._initialized, "Thread.__init__() was not called"
AssertionError: Thread.__init__() was not called

编码:

import threading
import logging
import time

class ThreadsWithSync(threading.Thread):

def __new__(cls):
    """
    For object creation
    """
    print("cls: %s"%(cls))
    cls.onCreateObject()
    
@classmethod
def onCreateObject(cls):
    """
    This will be invoked once the creation procedure of the object begins.
    """
    instance = super(ThreadsWithSync, cls).__new__(cls)
    print(instance)
    return instance

def __init__(self):
    """
    For object initialization
    """
    threading.Thread.__init__(self)
    print("self: %s"%(self))
    self.onInitializeObject()

def onInitializeObject(self):
    """
    This will be invoked once the initialization procedure of the object begins.
    """
    print("self: %s"%(self))
    
ThreadsWithSync()

解决方案

__repr__中的__repr__检查对象是否已初始化。当您在onCreateObject内部执行print(instance)时,将调用此函数。该检查是__repr__实现正常运行所必需的(不会引发AttributeError)。

如果覆盖threading.Thread中的__repr__,则您的示例将起作用

class ThreadWithSync(threading.Thread):
    ...
    def __repr__(self):
        return "hey"

这将导致输出:

cls: <class '__main__.ThreadsWithSync'>
hey

编辑以添加完整示例:

import threading


class ThreadsWithSync(threading.Thread):
    def __new__(cls):
        """
        For object creation
        """
        print("cls: %s" % (cls))
        cls.onCreateObject()

    @classmethod
    def onCreateObject(cls):
        """
        This will be invoked once the creation procedure of the object begins.
        """
        instance = super(ThreadsWithSync, cls).__new__(cls)
        print(instance)
        return instance

    def __init__(self):
        """
        For object initialization
        """
        super(ThreadsWithSync, self).__init__(self)
        print("self: %s" % (self))
        self.onInitializeObject()

    def onInitializeObject(self):
        """
        This will be invoked once the initialization procedure of the object begins.
        """
        print("self: %s" % (self))

    def __repr__(self):
        return id(self)


ThreadsWithSync()

相关文章