千锋教育-做有情怀、有良心、有品质的职业教育机构

400-811-9990
手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

上海
  • 北京
  • 郑州
  • 武汉
  • 成都
  • 西安
  • 沈阳
  • 广州
  • 南京
  • 深圳
  • 大连
  • 青岛
  • 杭州
  • 重庆
当前位置:武汉千锋IT培训  >  技术干货  >  Python线程编程的两种方式

Python线程编程的两种方式

来源:千锋教育
发布人:xqq
时间: 2023-11-11 12:37:29

Python中如果要使用线程的话,python的lib中提供了两种方式。一种是函数式,一种是用类来包装的线程对象。举两个简单的例子希望起到抛砖引玉的作用,关于多线程编程的其他知识例如互斥、信号量、临界区等请参考python的文档及相关资料。

1、调用thread模块中的start_new_thread()函数来产生新的线程,请看代码:

#thread_example.py

importtime

importthread

deftimer(no,interval):#自己写的线程函数

whileTrue:

print'Thread:(%d)Time:%s'%(no,time.ctime())

time.sleep(interval)

deftest():

thread.start_new_thread(timer,(1,1))#使用thread.start_new_thread()产生2个新的线程

thread.start_new_thread(timer,(2,3))

if__name__=='__main__':

test()

这个是thread.start_new_thread(function,args[,kwargs])函数原型,其中function参数是你将要调用的线程函数;args是讲传递给你的线程函数的参数,他必须是个tuple类型;而kwargs是可选的参数。线程的结束一般依靠线程函数的自然结束;也可以在线程函数中调用thread.exit(),他抛出SystemExitexception,达到退出线程的目的。

2、通过调用threading模块继承threading.Thread类来包装一个线程对象。请看代码#threading_example.py

importthreading

importtime

classtimer(threading.Thread):#我的timer类继承自threading.Thread类

def__init__(self,no,interval):

threading.Thread.__init__(self)#在我重写__init__方法的时候要记得调用基类的__init__方法

self.no=no

self.interval=interval

defrun(self):#重写run()方法,把自己的线程函数的代码放到这里

whileTrue:

print'ThreadObject(%d),Time:%s'%(self.no,time.ctime())

time.sleep(self.interval)

deftest():

threadone=timer(1,1)#产生2个线程对象

threadtwo=timer(2,3)

threadone.start()#通过调用线程对象的.start()方法来激活线程

threadtwo.start()

if__name__=='__main__':

test()

其实thread和threading的模块中还包含了其他的很多关于多线程编程的东西,例如锁、定时器、获得激活线程列表等等,相关资料仔细参考python的文档!

以上内容为大家介绍了Python线程编程的两种方式,希望对大家有所帮助,如果想要了解更多Python相关知识,请关注IT培训机构:千锋教育。http://www.mobiletrain.org/

声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。

猜你喜欢LIKE

在python中如何打乱数据?

2023-11-11

python架构是什么?

2023-11-11

python 列表排序

2023-11-11

最新文章NEW

python 抽象类和接口类

2023-11-11

python 的 Keras函数式模型

2023-11-11

Python生成表达式和列表解析

2023-11-11

相关推荐HOT

更多>>

快速通道 更多>>

最新开班信息 更多>>

网友热搜 更多>>