python 多线程之thread的解决办法
内容摘要
这篇文章主要为大家详细介绍了python 多线程之thread的简单示例,具有一定的参考价值,可以用来参考一下。
对python这个高级语言对此感兴趣的朋友,看看idc笔记做的技术笔记!
pyt
对python这个高级语言对此感兴趣的朋友,看看idc笔记做的技术笔记!
pyt
文章正文
这篇文章主要为大家详细介绍了python 多线程之thread的简单示例,具有一定的参考价值,可以用来参考一下。
对python这个高级语言对此感兴趣的朋友,看看idc笔记做的技术笔记!python 多线程之thread
# @param python 多线程之thread
# @author php教程|512Pic.com
#! /usr/bin/env python
# -*- coding:utf-8 -*-
from threading import Thread
import subprocess
from Queue import Queue
num_threads = 3
ips = ['10.108.100.174', '119.75.218.77', '127.0.0.1']
q = Queue()
def pingit(i, queue):
while True:
ip = queue.get()
print "thread %s is pinging %s" % (i, ip)
ret = subprocess.call('ping -c 3 %s' % ip, shell=True, stdout=open('/dev/null','w'))#正常则返回0,异常则返回1;stdout=open('/dev/null','w')屏蔽ping具体细节信息
if ret != 0:
print "%s is down" % ip
queue.task_done()
for i in xrange(num_threads):#xrang比range好
t = Thread(target=pingit, args=(i, q))
t.setDaemon(True)#设置了setDaemon则线程会随着主线程关闭而关闭,python中,主线程结束后,会默认等待子线程结束后,主线程才退出
t.start()
for ip in ips:
q.put(ip)
print "main thread is waiting..."
q.join()
print "Done..."
# End www_512pic_com
注:关于python 多线程之thread的简单示例的内容就先介绍到这里,更多相关文章的可以留意
代码注释