Нить Питона.start() вызывает AttributeError


Когда я кодировал клиент-серверную систему на python, я наткнулся на странную ошибку в stdout сервера, которая не должна была произойти:

Traceback (most recent call last):
  File "C:UsersAdamDriveDJdaemonServermain.py", line 33, in <module>
    ClientThread(csock, addr).start()
AttributeError: 'ClientThread' object has no attribute '_initialized'

Я разделил строку на несколько строк, и именно start() вызвал ошибку.

Есть идеи? Вот исходный код сервера-клиент просто открывает и закрывает соединение:

import socket, threading

class ClientThread(threading.Thread):
    def __init__(self, sock, addr):
        self.sock = sock
        self.addr = addr
    def run(self):
        sock = self.sock
        addr = self.addr

        while True:
            msg = sock.recv(1024).decode()
            if not msg:
                print('Disconnect: ' + addr[0] + ':' + str(addr[1]))
                sock.close()
                return

# Constants
SERVER_ADDRESS = ('', 25566)
MAX_CLIENTS = 10
MCSRV_ADDRESS = ('localhost', 25567)

srv = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
srv.bind(SERVER_ADDRESS)
srv.listen(MAX_CLIENTS)

udp = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)

while True:
    (csock, addr) = srv.accept()
    print('Connect: ' + addr[0] + ':' + str(addr[1]))
    ClientThread(csock, addr).start()
1 2

1 ответ:

Вы забыли вызвать Родительский контруктор ClientThread в __init__.

def __init__(self, sock, addr):
    super(ClientThread, self).__init__()
    self.sock = sock
    self.addr = addr