实例如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
|
#!/usr/bin/env python # -*- coding: utf-8 -*- import socket #创建一个socket对象 sk1 = socket.socket() #绑定ip和端口 sk1.bind(('127.0.0.1', 8001)) #监听 sk1.listen() #定义一个字典存放客户端发送的信息 message_dict = {} #inputs用于存放socket对象 inputs = [sk1] #哪一个客户端发送信息就把哪一个客户端的存放进output output = [] import select while True: r_list, w_list, e_list = select.select(inputs, output, inputs, 1) print('正在监听的socket%d' %len(inputs)) print(r_list) for sk_or_conn in r_list: if sk_or_conn == sk1: conn, address = sk_or_conn.accept() inputs.append(conn) message_dict[conn] = [] else: try: data_bytes = sk_or_conn.recv(1024) except Exception as ex: inputs.remove(sk_or_conn) else: data_str = str(data_bytes, encoding='utf-8') message_dict[sk_or_conn].append(data_str) output.append(sk_or_conn) for conn in w_list: data_message = message_dict[sk_or_conn][0] del message_dict[sk_or_conn][0] conn.sendall(bytes(data_message + '好',encoding='utf-8')) output.remove(conn) |
以上这篇socket + select 完成伪并发操作的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:http://www.cnblogs.com/doupy/p/7359835.html