#coding=gbk
#Python中的线程处理
'''
Python中对多线程有两种启动方法:
一种是thread模块的start_new_thread方法,在线程中运行一个函数,但获得函数返回值极为困难,Python官方不推荐
另一种是集成threading模块的Thread类,然后重写run方法,类似于Java的Runnable接口定义,灵活性较高
'''
print "=======================thread.start_new_thread启动线程============="
import thread
#Python的线程sleep方法并不是在thread模块中,反而是在time模块下
import time
def inthread(no,interval):
count=0
while count<10:
print "Thread-%d,休眠间隔:%d,current Time:%s"%(no,interval,time.ctime())
#使当前线程休眠指定时间,interval为浮点型的秒数,不同于Java中的整形毫秒数
time.sleep(interval)
#Python不像大多数高级语言一样支持++操作符,只能用+=实现
count+=1
else:
print "Thread-%d is over"%no
#可以等待线程被PVM回收,或主动调用exit或exit_thread方法结束线程
thread.exit_thread()
#使用start_new_thread函数可以简单的启动一个线程,第一个参数指定线程中执行的函数,第二个参数为元组型的传递给指定函数的参数值
thread.start_new_thread(inthread,(1,2))
#线程执行时必须添加这一行,并且sleep的时间必须足够使线程结束,如本例
#如果休眠时间改为20,将可能会抛出异常
time.sleep(30)
'''
使用这种方法启动线程时,有可能出现异常Unhandled exception in thread started by
Error in sys.excepthook:
Original exception was:
解决:启动线程之后,必须调用time.sleep休眠足够长的时间,使主线程等待所有子线程返回结果,如果主线程比子线程早结束,就会抛出这个异常
具体的跟Python的多线程机制有关,参见http://bestchenwu.iteye.com/blog/1063401
'''
分享到:
相关推荐
本压缩包“PYthon-multithreading-Test.rar”包含了有关Python多线程测试的源码,旨在帮助用户深入理解和实践Python的线程操作。 Python中的多线程是通过`threading`模块实现的,这个模块提供了基本的线程和同步...
需要注意的是,由于Python的全局解释器锁(GIL),即使使用了多线程,CPU密集型任务的执行并不会真正并行。但是,对于I/O密集型任务,如网络请求或文件读写,线程可以提高程序的并发性能。 在实际应用中,根据任务...
### Python多线程学习 在Python中,使用线程主要有两种方法:一是通过函数的方式,二是利用类来封装线程对象。这两种方式都是基于Python的标准库`thread`和`threading`来实现的。 #### 函数方式创建线程 使用`...
### Python多线程处理 #### 一、简介 在Python编程语言中,多线程是一种常见的并发编程模型,它允许程序同时执行多个任务。多线程可以显著提高程序的效率和响应能力,尤其是在处理I/O密集型操作时,如网络请求、...
在Python编程中,多线程同步对于文件读写控制至关重要,因为如果不加以控制,多个线程同时访问同一文件可能会导致数据不一致或者错误。这里我们将深入探讨如何在Python中使用多线程同步来确保文件读写的安全性。 ...
本文将深入探讨如何在Windows环境下利用Python的多线程技术来高效地爬取1000个网页。我们将围绕"多线程爬取1000个网页"这一主题,结合"thread"标签进行讲解。 Python的`threading`模块是实现多线程的基础,它允许...
在Python编程中,多线程是一种并发执行任务的机制,尤其在处理I/O密集型任务如网络请求时,能够显著提高程序效率。本教程将详细讲解如何使用Python的多线程来实现对多个网址的快速访问,并记录访问结果。 首先,...
在本文中,我们将介绍 Python 中的多线程编程基础知识,包括多线程编程的定义、优点、 thread 模块的使用等。 多线程编程的定义 ---------------- 多线程编程是指在一个程序中同时执行多个线程的技术。每个线程都...
经常会遇到下述问题:很多io busy的应用采取多线程的方式来解决,但这时候会发现python命令行不响应ctrl-c 了,而对应的java代码则没有问题: 复制代码 代码如下: public class Test { public static void main...
总结起来,`python多线程定时器`的实现涉及到Python的`threading`和`time`模块,通过`Thread`和`Timer`类来创建和管理线程,使用定时器控制线程的启动时间。主程序`main.py`使用这些工具来安排多个任务按设定的间隔...
### Python多线程处理 #### 一、Python多线程简介与应用场景 Python中的多线程主要用于并发处理,尤其适用于I/O密集型而非CPU密集型的任务。这是因为Python的全局解释器锁(GIL)限制了多线程在单个CPU核心上的...
Python多线程编程在实现网络串口透传中扮演着重要的角色,特别是在处理TCP客户端网口数据时。网络串口透传技术允许通过网络连接模拟串行通信,使得远程设备可以像连接本地串口一样进行通信。这在物联网(IoT)、远程...
Python多线程下载管理是一种利用Python编程语言实现的高效下载技术,它通过开启多个线程同时处理下载任务,显著提高了文件下载的速度。在现代互联网环境中,处理大量数据或大文件时,多线程技术显得尤为重要,因为它...
在这个"Guest_replace_File.rar_python多线程"项目中,我们看到一个Python脚本`Guest_replace_File.py`,它很可能涉及到了在多个线程中替换文本的操作。下面我们将详细讨论Python多线程以及可能在该脚本中用到的技术...
在Python编程中,多线程和非阻塞的Socket技术是构建高效网络应用程序的关键组成部分。本文将深入探讨如何在Python中实现多线程非阻塞的Socket服务端和客户端,以提升并发处理能力。 首先,让我们理解“多线程”和...
Python多线程编程是Python系统编程中的重要组成部分,它允许程序同时执行多个任务,从而提高程序的效率和响应速度。在Python中,我们通常使用内置的`thread`库、`threading`库以及`Queue`库来实现多线程。 首先,`...
Python中的多线程是并发执行任务的一种方式,它允许程序同时处理多个任务,提升程序的效率。在Python中,我们通常使用`threading`模块来实现多线程,而不是`thread`模块,因为`threading`模块提供了更高级别的功能和...
Python的多线程是Python编程中的一个重要概念,特别是在处理大量数据或者需要同时执行多个任务时。在Python 2.x版本中,多线程是通过`threading`模块来实现的。下面将详细介绍Python 2.x版本中的多线程以及相关的...
在Python编程语言中,多线程是实现并发执行任务的重要机制。它允许程序同时执行多个不同的任务,从而提高效率和响应速度。在这个基于Python的多线程例子中,我们将深入探讨如何创建和管理线程,以及如何利用它们来...