Нить Питона.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()