您好,我有一个程序可以查看一系列数据并在该数据中发现异常。为了使我的程序更快,我现在合并了线程(总共 66 个)的使用,当我的程序发现异常时,我希望它将其写入文件,但是当我尝试从多个线程中写入文件时,它不会写入.
class myThread(threading.Thread):
def __init__(self,arg1,arg2,lock,output):
threading.Thread.__init__(self)
self.arg1 = arg1
self.arg2 = arg2
self.lock = lock
self.file = output
def run(self):
# print "Starting " + self.name
main(self.arg1,self.arg2,self.lock,self.file)
# print "Exiting " + self.name
def main(START_IP,END_IP,lock,File):
# store found DNS servers
foundDNS=[]
# scan all the ip addresses in the range
for i0 in range(START_IP[0], END_IP[0]+1):
for i1 in range(START_IP[1], END_IP[1]+1):
for i2 in range(START_IP[2], END_IP[2]+1):
for i3 in range(START_IP[3], END_IP[3]+1):
# build ip addres
ipaddr=str(i0)+"."+str(i1)+"."+str(i2)+"."+str(i3)
print "Scanning "+ipaddr+"...",
# scan address
ret=ScanDNS(ipaddr, 10)
if ret==True:
foundDNS.append(ipaddr)
print "Found!"
lock.acquire()
File.write(ipaddr)
File.write("\n")
File.flush()
lock.release()
else:
print
file = open("file.txt","wb")
lock = threading.Lock()
thread1 = myThread(START_IP,END_IP,lock,)
thread1.start()
这使用了我完全相同的 MyThread 类,只是带有 main 操作数据所需的参数。如果我在扫描 DNS 服务器时运行我的代码大约一分钟,我应该将 20-30 个 DNS 服务器保存到一个文件中,但我通常会得到这个:
文件.TXT
2.2.1.2
8.8.8.8
31.40.40
31.31.40.40
31.31.41.41
我知道一个事实(因为我观察了扫描输出)并且它几乎没有写完所有这些。那么为什么有的写有的没有呢?