Path: csiph.com!v102.xanadu-bbs.net!xanadu-bbs.net!goblin2!goblin.stu.neva.ru!newsfeed.xs4all.nl!newsfeed4.news.xs4all.nl!xs4all!post.news.xs4all.nl!not-for-mail Return-Path: X-Original-To: python-list@python.org Delivered-To: python-list@mail.python.org X-Spam-Status: OK 0.008 X-Spam-Evidence: '*H*': 0.98; '*S*': 0.00; '"""': 0.07; '-*-': 0.07; 'debug': 0.07; 'utf-8': 0.07; 'coding:': 0.09; 'line:': 0.09; 'subject:Why': 0.09; 'try:': 0.09; 'python': 0.11; 'def': 0.12; 'empty.': 0.16; 'subject:threads': 0.16; 'true:': 0.16; 'subject: ?': 0.16; 'example': 0.22; 'import': 0.22; 'print': 0.22; 'skip:l 30': 0.24; 'script': 0.25; 'message-id:@mail.gmail.com': 0.30; 'class': 0.32; 'skip:# 10': 0.33; 'skip:_ 10': 0.34; 'except': 0.35; 'received:google.com': 0.35; 'list': 0.37; 'skip:o 20': 0.38; 'skip:& 10': 0.38; 'to:addr:python-list': 0.38; 'list,': 0.38; 'to:addr:python.org': 0.39; 'skip:p 20': 0.39; 'break': 0.61; 'skip:t 30': 0.61; 'from:charset:utf-8': 0.61; '8bit%:95': 0.64; 'hang': 0.67; 'url:me': 0.69; '8bit%:94': 0.72; 'here."': 0.91; '8bit%:90': 0.93 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=mime-version:date:message-id:subject:from:to:content-type; bh=u37qFEdqpRxD0jG9k+Dfky+w0mOsYdJ9qDLapuZ7g9E=; b=wvZLmVZuYjlKAHffSH4U1AaX9zn5bfyn2G/FjG8STuKszf8RI4ZCdvyVvQ7oQoRfUU M5kILncJJ4oAuoBIXnzxeoC/CZOC8+JykN+sH/BkZu6cigvBu1qbls+OMUApHCVsiW8i eNpDHQFpPODSpY5cIuqyk58AP9jXqTapLEeI8j+f7iiWWeTgEA/5UDlxZYSrEJn+lMur 2QrxY91LzOqqYT6IyafhJ2FT9bVs4an+o6Q4DkS8coF6+GLZEjWOCVyr9E0N0duX1rdF l+N0YsGr0Rvw+b0yNtdCy098Kq3DkVYSFydv0g0+O7c+osNK5IkaPE8ltDMkD0t4DYau 6H0w== MIME-Version: 1.0 X-Received: by 10.194.240.129 with SMTP id wa1mr8276560wjc.31.1380821840329; Thu, 03 Oct 2013 10:37:20 -0700 (PDT) Date: Fri, 4 Oct 2013 01:37:20 +0800 Subject: Why didn't my threads exit correctly ? From: =?UTF-8?B?5p2O5rSb?= To: python-list@python.org Content-Type: multipart/alternative; boundary=089e013d1db24a83c004e7d9a363 X-Mailman-Approved-At: Thu, 03 Oct 2013 19:55:39 +0200 X-BeenThere: python-list@python.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: General discussion list for the Python programming language List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Newsgroups: comp.lang.python Message-ID: Lines: 109 NNTP-Posting-Host: 2001:888:2000:d::a6 X-Trace: 1380822940 news.xs4all.nl 16009 [2001:888:2000:d::a6]:44151 X-Complaints-To: abuse@xs4all.nl Xref: csiph.com comp.lang.python:55431 --089e013d1db24a83c004e7d9a363 Content-Type: text/plain; charset=UTF-8 Hi list, I write an example script using threading as follow. It look like hang when the list l_ip is empty. And any suggestion with debug over the threading in Python ? 1 #!/usr/bin/env python 2 # -*- coding: utf-8 -*- 3 import re 4 import os 5 import threading 6 from Queue import Queue 7 from time import sleep 8 9 l_ip = [] 10 l_result = [] 11 result = re.compile(r"[1-3] received") 12 13 class ping(threading.Thread): 14 """ """ 15 def __init__(self, l_ip, l_result): 16 threading.Thread.__init__(self) 17 self.l_ip = l_ip 18 #self.l_result = l_result 19 20 def run(self): 21 """ """ 22 while True: 23 try: 24 ip = self.l_ip.pop() 25 except IndexError as e: 26 print e 27 break 28 ping_out = os.popen(''.join(['ping -q -c3 ',ip]), 'r') 29 print 'Ping ip:%s' % ip 30 while True: 31 line = ping_out.readline() 32 if not line: break 33 if result.findall(line): 34 l_result.append(ip) 35 break 36 37 queue = Queue() 38 39 for i in range(1,110): 40 l_ip.append(''.join(['192.168.1.', str(i)])) 41 for i in xrange(10): 42 t = ping(l_ip, l_result) 43 t.start() 44 queue.put(t) 45 queue.join() 46 print "Result will go here." 47 for i in l_result: 48 print 'IP %s is OK' % i -- All the best! http://luolee.me --089e013d1db24a83c004e7d9a363 Content-Type: text/html; charset=UTF-8 Content-Transfer-Encoding: base64 PGRpdiBkaXI9Imx0ciI+PGRpdj5IaSBsaXN0LDxicj5JIHdyaXRlIGFuIGV4YW1wbGUgc2NyaXB0 IHVzaW5nIHRocmVhZGluZyBhcyBmb2xsb3cuPGJyPjwvZGl2Pkl0IGxvb2sgbGlrZSBoYW5nIHdo ZW4gdGhlIGxpc3QgbF9pcCBpcyBlbXB0eS4gQW5kIGFueSBzdWdnZXN0aW9uIHdpdGggZGVidWcg b3ZlciB0aGUgdGhyZWFkaW5nIGluIFB5dGhvbiA/IDxicj48ZGl2Pjxicj7CoCAxICMhL3Vzci9i aW4vZW52IHB5dGhvbjxicj4NCsKgIDIgIyAtKi0gY29kaW5nOiB1dGYtOCAtKi08YnI+wqAgMyBp bXBvcnQgcmU8YnI+wqAgNCBpbXBvcnQgb3M8YnI+wqAgNSBpbXBvcnQgdGhyZWFkaW5nPGJyPsKg IDYgZnJvbSBRdWV1ZSBpbXBvcnQgUXVldWU8YnI+wqAgNyBmcm9tIHRpbWUgaW1wb3J0IHNsZWVw PGJyPsKgIDggPGJyPsKgIDkgbF9pcCA9IFtdPGJyPsKgMTAgbF9yZXN1bHQgPSBbXTxicj7CoDEx IHJlc3VsdCA9IHJlLmNvbXBpbGUociZxdW90O1sxLTNdIHJlY2VpdmVkJnF1b3Q7KTxicj4NCsKg MTIgPGJyPsKgMTMgY2xhc3MgcGluZyh0aHJlYWRpbmcuVGhyZWFkKTo8YnI+wqAxNMKgwqDCoMKg ICZxdW90OyZxdW90OyZxdW90OyAmcXVvdDsmcXVvdDsmcXVvdDs8YnI+wqAxNcKgwqDCoMKgIGRl ZiBfX2luaXRfXyhzZWxmLCBsX2lwLCBsX3Jlc3VsdCk6PGJyPsKgMTbCoMKgwqDCoMKgwqDCoMKg IHRocmVhZGluZy5UaHJlYWQuX19pbml0X18oc2VsZik8YnI+wqAxN8KgwqDCoMKgwqDCoMKgwqAg c2VsZi5sX2lwID0gbF9pcDxicj7CoDE4wqDCoMKgwqDCoMKgwqDCoCAjc2VsZi5sX3Jlc3VsdCA9 IGxfcmVzdWx0PGJyPg0KwqAxOSA8YnI+wqAyMMKgwqDCoMKgIGRlZiBydW4oc2VsZik6PGJyPsKg MjHCoMKgwqDCoMKgwqDCoMKgICZxdW90OyZxdW90OyZxdW90OyAmcXVvdDsmcXVvdDsmcXVvdDs8 YnI+wqAyMsKgwqDCoMKgwqDCoMKgwqAgd2hpbGUgVHJ1ZTo8YnI+wqAyM8KgwqDCoMKgwqDCoMKg wqDCoMKgwqDCoCB0cnk6PGJyPsKgMjTCoMKgwqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgwqDCoCBp cCA9IHNlbGYubF9pcC5wb3AoKTxicj7CoDI1wqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgIGV4Y2Vw dCBJbmRleEVycm9yIGFzIGU6PGJyPg0KwqAyNsKgwqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgwqDC oMKgIHByaW50IGU8YnI+wqAyN8KgwqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgIGJyZWFr PGJyPsKgMjjCoMKgwqDCoMKgwqDCoMKgwqDCoMKgwqAgcGluZ19vdXQgPSBvcy5wb3BlbigmIzM5 OyYjMzk7LmpvaW4oWyYjMzk7cGluZyAtcSAtYzMgJiMzOTssaXBdKSwgJiMzOTtyJiMzOTspPGJy PsKgMjnCoMKgwqDCoMKgwqDCoMKgwqDCoMKgwqAgcHJpbnQgJiMzOTtQaW5nIGlwOiVzJiMzOTsg JSBpcDxicj7CoDMwwqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgIHdoaWxlIFRydWU6PGJyPg0KwqAz McKgwqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgIGxpbmUgPSBwaW5nX291dC5yZWFkbGlu ZSgpPGJyPsKgMzLCoMKgwqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgwqDCoCBpZiBub3QgbGluZTog YnJlYWs8YnI+wqAzM8KgwqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgIGlmIHJlc3VsdC5m aW5kYWxsKGxpbmUpOjxicj7CoDM0wqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKg wqDCoCBsX3Jlc3VsdC5hcHBlbmQoaXApPGJyPsKgMzXCoMKgwqDCoMKgwqDCoMKgwqDCoMKgwqDC oMKgwqDCoMKgwqDCoMKgIGJyZWFrPGJyPsKgMzYgPGJyPg0KwqAzNyBxdWV1ZSA9IFF1ZXVlKCk8 YnI+wqAzOCA8YnI+wqAzOSBmb3IgaSBpbiByYW5nZSgxLDExMCk6PGJyPsKgNDDCoMKgwqDCoCBs X2lwLmFwcGVuZCgmIzM5OyYjMzk7LmpvaW4oWyYjMzk7MTkyLjE2OC4xLiYjMzk7LCBzdHIoaSld KSk8YnI+wqA0MSBmb3IgaSBpbiB4cmFuZ2UoMTApOjxicj7CoDQywqDCoMKgwqAgdCA9IHBpbmco bF9pcCwgbF9yZXN1bHQpPGJyPsKgNDPCoMKgwqDCoCB0LnN0YXJ0KCk8YnI+wqA0NMKgwqDCoMKg IHF1ZXVlLnB1dCh0KTxicj4NCsKgNDUgcXVldWUuam9pbigpPGJyPsKgNDYgcHJpbnQgJnF1b3Q7 UmVzdWx0IHdpbGwgZ28gaGVyZS4mcXVvdDs8YnI+wqA0NyBmb3IgaSBpbiBsX3Jlc3VsdDo8YnI+ wqA0OMKgwqDCoMKgIHByaW50ICYjMzk7SVAgJXMgaXMgT0smIzM5OyAlIGk8YnIgY2xlYXI9ImFs bCI+PGRpdj48YnI+LS0gPGJyPjxkaXYgZGlyPSJsdHIiPjxkaXY+QWxsIHRoZSBiZXN0ITxicj48 YnI+PC9kaXY+PGRpdj48YSBocmVmPSJodHRwOi8vbHVvbGVlLm1lIiB0YXJnZXQ9Il9ibGFuayI+ aHR0cDovL2x1b2xlZS5tZTwvYT48YnI+DQo8L2Rpdj48L2Rpdj4NCjwvZGl2PjwvZGl2PjwvZGl2 Pg0K --089e013d1db24a83c004e7d9a363--