Python中的多线程传输

时间:2018-12-19 08:15:50

标签: python multithreading python-2.7 netty

我使用Python客户端连接Netty服务器。

客户:

import socket 
from datetime import datetime
import csv
import threading
import sys
import time

starttimes = sys.argv[1]
starttimes = int(starttimes)
endtimes = sys.argv[2]
endtimes = int(endtimes)
times = endtimes - starttimes

open('result.csv','w').close()
csv_file = 'result.csv'

def loop():
    TCP_IP = "127.0.0.1"
    TCP_PORT = 9999                   # The same port as used by the server
    s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    s.connect((TCP_IP, TCP_PORT))
    timereq = datetime.now()
    timereq2 = datetime.strftime(timereq, '%Y-%m-%d,%H:%M:%S.%f')
    timereq3 = time.time()
    s.sendall("\x00\x00"+i)
    res = s.recv(4096)
    print res
    timeres = datetime.now()
    timeres2 = datetime.strftime(timeres, '%Y-%m-%d,%H:%M:%S.%f')
    timeres3 = time.time()
    s.close()
    print('Received', repr(res))
    cost = timeres3 - timereq3
    cost = "%.3f" % cost
    with open(csv_file, 'a') as csvfile:

        writer = csv.writer(csvfile)
        writer.writerow([timereq2, timeres2, cost])


threads = []
for i in range(starttimes,endtimes+1):
    i =chr(i)
    t = threading.Thread(target=loop)
    threads.append(t)
    t.start()

例如,我在1到10之间的多线程中设置了变量“ i”,服务器中的理想结果是获得“ i = 1、2、3、4、5、6、7、8、9、10 “。

但有时会出错,例如“ i = 1、2、2、4、5、7、7、8、9、10”或“ i = 3、3、3、3、5” 5、5、8、9、9”。

请帮助我解决问题。

谢谢。

1 个答案:

答案 0 :(得分:0)

您正在使用同时已更改的局部变量i。 这样传递:

threading.Thread(target=loop, args=(i,))

并将其添加为loop函数的参数:

def loop(i):
    ...