多线程并发模型

【多线程并发模型】

基于threading的多线程并发

1.对比多进程并发:
1.优点:
资源消耗小
2.缺点:
需要注意共享资源的争夺
python多线程收到GIL的影响
2.实现方式:
threading socket 模块完成

3.实现步骤:
1.创建套接字,绑定,监听
2.接收客户端连接请求,创建新的线程
3.主线程继续等待其他客户端连接,分支线程执行客户端请求
4.处理完客户端请求后,分支线程退出,关闭客户端套接字

4.示例:

from socket import *
from threading import Thread
import sys

HOST = '0.0.0.0'
PORT = 8888
ADDR = (HOST,PORT)

def client_handle(c):
    print('Connect from',c.getpeername())
    while True:
	data = c.recv(1024).decode()
	if not data:
	    break
	print(data)
	c.send(b'Recieve your message')
    c.close()

# 创建套接字
s = socket()
# 设置端口可重用
s.setsockopt(SOL_SOCKET,SO_REUSEADDR,1)
s.bind(ADDR)
s.listen()

# 循环接收客户端请求
while True:
    try:
	c,addr = s.accept()
    except KeyboardInterrupt:
	s.close()
	sys.exit('服务器退出')
    except Exception as e:
	print(e)
	continue

    # 创建线程,绑定函数执行具体客户端请求
    t = Thread(target=client_handle,args=(c,))
    t.setDaemon(True)
    t.start()

客户端代码

from socket import * 

# 创建套接字
sockfd = socket(AF_INET,SOCK_STREAM)

# 发起连接
sockfd.connect(('176.130.5.63',8888))

while True:

    data = input('发送>>>')
    if not data:
	break
    # 将内容变成bytes格式发送
    sockfd.send(data.encode())

    # 接受消息
    data = sockfd.recv(1024).decode()
    print('收到消息:',data)

# 关闭套接字
sockfd.close()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值