多线程类似于同时执行多个不同的程序。多线程具有以下优点:
使用线程可以将程序中占用较长时间的任务放到后台处理。用户界面可以更吸引人,例如当用户点击按钮触发某些事件的处理时,可以弹出一个进度条来显示处理的进度。在执行一些等待任务如用户输入、文件线程时,程序的运行速度可能会加快,对于通过网络读写和发送和接收数据更有用。在这种情况下,我们可以释放一些宝贵的资源,例如内存使用量等。
线程在执行过程中仍然不同于进程。每个独立的进程都有一个程序执行入口、一个顺序执行序列和一个程序出口。但是线程不能独立执行,必须依赖于应用程序,应用程序提供多线程执行控制。
每个线程都有自己的一组 CPU 寄存器,称为线程的上下文,它反映了线程最后一次运行线程时 CPU 寄存器的状态。
指令指针和堆栈指针寄存器是线程上下文中最重要的两个寄存器。线程始终在进程的上下文中运行,这些地址用于在拥有该线程的进程的地址空间中标记内存。
线程可以被抢占(中断)。当其他线程正在运行时,线程可以暂停(也称为休眠)一段时间——这是线程的产量。
在 Python 中有两种使用线程的方法:封装线程对象的函数或类。
函数式:调用thread模块中的start_new_thread()函数生成一个新线程。语法如下:
thread.start_new_thread ( function, args[, kwargs] )
参数说明:
function - 线程函数。
args - 传递给线程函数的参数,他必须是个tuple类型。
kwargs - 可选参数。
实例
import thread
import time
# 为线程定义一个函数
def print_time( threadName, delay):
count = 0
while count < 5:
time.sleep(delay)
count += 1
print "%s: %s" % ( threadName, time.ctime(time.time()) )
# 创建两个线程
try:
thread.start_new_thread( print_time, ("Thread-1", 2, ) )
thread.start_new_thread( print_time, ("Thread-2", 4, ) )
except:
print "Error: unable to start thread"
while 1:
pass
以上程序输出结果
Thread-1: Thu Jan 22 15:42:17 2009
Thread-1: Thu Jan 22 15:42:19 2009
Thread-2: Thu Jan 22 15:42:19 2009
Thread-1: Thu Jan 22 15:42:21 2009
Thread-2: Thu Jan 22 15:42:23 2009
Thread-1: Thu Jan 22 15:42:23 2009
Thread-1: Thu Jan 22 15:42:25 2009
Thread-2: Thu Jan 22 15:42:27 2009
Thread-2: Thu Jan 22 15:42:31 2009
Thread-2: Thu Jan 22 15:42:35 2009
本文为原创文章,版权归知行编程网所有,欢迎分享本文,转载请保留出处!
你可能也喜欢
- ♥ python中iter函数的使用方法11/20
- ♥ 如何在python中获取当前时间08/13
- ♥ python Package如何设置文件入口11/09
- ♥ 深入理解Python中的生成器12/11
- ♥ 人工智能python好学吗?11/19
- ♥ 如何使用python实现文本数据挖掘?01/13
内容反馈