单线程一对一聊天请看上一篇:https://blog.csdn.net/weixin_41427294/article/details/84594714
由于input函数的阻塞作用,以上的代码发完一条信息,只能等待另一端的信息发过来才能继续发送。
这时就要考虑将输入与接收分开来,将接收的函数(或方法)从主线程里抓出来丢到另一个线程里单独运行,为实现这一功能,必须引入多线程。
多线程的使用别人的教程写得都太杂乱,什么select都来了……,其实很简单,Python里两句话搞定,需要import threading
接收的方法为recv,就把clientsocket.recv()写到其他函数里,然后主函数里让它自己跑起来:
trd=threading.Thread(target=rec,args=(sock,))
trd.start()
target参数为需要跑起来的函数名,仅函数名,不需要括号,args为传递到target函数里的参数(元组类型),这里仅传入收发数据用的socket对象即可
改良后的代码(须在CMD里运行):
服务端:
import socket
import threading
serversocket = socket.socket(
socket.AF_INET, socket.SOCK_STREAM)
# sckt.connect(('DESKTOP-EOLEIAV',9999))
host = socket.gethostname() #本机地址
port = 9999
serversocket.bind((host, port))
serversocket.listen(5)
print("我在 ", host, " 等你...")
clientsocket,addr = serversocket.accept()
print("来自 %s" % str(addr))
true=True
def rec(clientsocket):
global true
while true:
msg=clientsocket.recv(1024).decode('gb2312')
#函数的核心语句就一条接收方法
if msg == "exit":
true=False
print(msg)
trd=threading.Thread(target=rec,args=(clientsocket,))
trd.start()
while true:
msg=input("->")
clientsocket.send(msg.encode('gb2312'))
if msg=="exit":
true=False
serversocket.close()
客户端:
import socket
import threading
sckt=socket.socket(
socket.AF_INET, socket.SOCK_STREAM)
sckt.connect(("DESKTOP-EOLEIAV",9999))
true=True
def rec(sckt):
global true
while true:
msg=sckt.recv(1024).decode('gb2312') #函数的核心语句就一条接收方法
if msg == "exit":
true=False
print(msg)
trd=threading.Thread(target=rec,args=(sckt,))
trd.start()
while True:
msg=input("->")
sckt.send(msg.encode('gb2312'))
if msg == "exit":
true=False
sckt.close()
参考代码文章:https://blog.csdn.net/p09080016/article/details/79096663