python多线程操作实例

一、python多线程

因为CPython的实现使用了Global Interpereter Lock(GIL),使得python中同一时刻只有一个线程在执行,从而简化了python解释器的实现,且python对象模型天然地线程安全。如果你想你的应用程序在多核的机器上使用更好的资源,建议使用multiprocessing或concurrent.futures.processpoolexecutor。但是如果你的程序是IO密集型,则使用线程仍然是很好的选择。

二、python多线程使用的两种方法

实例:

复制代码 代码如下:

立即学习“Python免费学习笔记(深入)”;

import threading
import time

def worker(num):
  print (threading.currentThread().getName() + ‘ start’)
  time.sleep(10)
  print (threading.currentThread().getName() + ‘ running’)
  print (threading.currentThread().getName() + ” ” + str(num))
  print (threading.currentThread().getName() + ‘ exit’)
 
def deamon():
  print (threading.currentThread().getName() + ‘ start’)
  time.sleep(20)
  print (threading.currentThread().getName() + ‘ running’)
  print (threading.currentThread().getName() + ‘ exit’)
 
print(threading.currentThread().getName())

d = threading.Thread(name=’deamon’, target=deamon)
d.setDaemon(True)
d.start()

w = threading.Thread(name=’worker’, target=worker, args=(10,))
w.start()

class myWorker(threading.Thread):
    def __init__(self, num): 
        threading.Thread.__init__(self) 
        self.num = num 
        self.thread_stop = False 
  
    def run(self):
        print (self.getName()+’ start’)
        time.sleep(30)
        print (self.getName()+’ running’)
        print (self.getName()+” ” + str(self.num))
        print (self.getName()+’ exit’)
 
mw = myWorker(30)
mw.setName(“MyWorker”)
mw.start()

print(threading.currentThread().getName())

print(“All threads:”)
print(“————“)
for th in threading.enumerate():
  print(th.getName())
print(“————“)

d.join()
w.join()
mw.join()

print(threading.currentThread().getName())

运行结果如下:

python多线程操作实例

1)python线程使用的两种方法:

**直接调用threading.Thread来构造thread对象,Thread的参数如下:
class threading.Thread(group=None, target=None, name=None, args=(), kwargs={}) 
group为None;
target为线程将要执行的功能函数;
name为线程的名字,也可以在对象构造后调用setName()来设定;
args为tuple类型的参数,可以为多个,如果只有一个也的使用tuple的形式传入,例如(1,);
kwargs为dict类型的参数,也即位命名参数;

**实现自己的threading.Thread的子类,需要重载__init__()和run()。

2)threading.Thread对象的其他方法:

start(),用来启动线程;
join(), 等待直到线程结束;
setDeamon(), 设置线程为deamon线程,必须在start()调用前调用,默认为非demon。
注意: python的主线程在没有非deamon线程存在时就会退出。

3)threading的静态方法:

threading.current_thread() , 用来获得当前的线程;
threading.enumerate() , 用来多的当前存活的所有线程;
threading.Timer 定时器,其实是thread的一个字类型,使用如下:

复制代码 代码如下:
def hello(): print(“hello, world”)  
t = Timer(30.0, hello)
t.start()

4)logging是线程安全的

logging 模块是线程安全的,所以可以使用logging来帮助调试多线程程序。

复制代码 代码如下:
import logging
logging.basicConfig(level=logging.DEBUG,
format=”(%(threadName)-10s : %(message)s”,
)
logging.debug(“wait_for_event_timeout starting”)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2292093.html

(0)
上一篇 2025年2月28日 01:29:30
下一篇 2025年2月28日 01:30:15

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 总结python Django在开发中的使用经验

    这次给大家带来总结python python在开发中的使用经验,在python django在开发中的python有哪些,下面就是实战案例,一起来看一下。 大三的时候第一次接触 Django,从真正使用 Django 做项目到现在也快 4 …

    编程技术 2025年4月4日
    100
  • Java 框架在其他编程语言中是否易于集成?

    java 框架可在多语言环境中集成,受平台兼容性、语言支持和中间层影响。平台兼容性:java 框架在 jvm 上运行,与 jvm 兼容的语言兼容。语言支持:部分 java 框架支持其他语言,如 groovy 和 kotlin。中间层:jna…

    2025年4月2日
    100
  • java框架与人工智能的集成应用

    java 框架与 ai 集成使应用程序能够利用 ai 技术,包括自动化任务、提供个性化体验和支持决策制定。通过直接调用或使用第三方库,java 框架可与 h2o.ai、weka 等框架无缝集成,从而实现数据分析、预测建模、神经网络训练等功能…

    2025年4月2日
    100
  • java编程接口怎么起头

    Java 编程接口 (API) 是一组预定义的方法和类,用于在应用程序中利用其他软件的的功能。开始使用 API 的步骤包括:了解 API 文档、导入 API、创建 API 对象、调用 API 方法和处理结果。例如,Java Collecti…

    2025年4月2日
    100
  • java怎么调用python

    通过 Jython、JPython、Hadoop Pig 或 Java Native Interface (JNI),可以从 Java 调用 Python 代码,各方法各有优势和劣势,具体选择取决于用例和要求。 如何从 Java 调用 Py…

    2025年4月2日
    100
  • java转python怎么转

    java 转 python 如何从 Java 转到 Python? 从 Java 转到 Python 的过程需要考虑以下步骤: 1. 学习 Python 基础 理解 Python 语法、数据类型、控制流和函数。了解 Python 的包和库生…

    编程技术 2025年4月2日
    100
  • java框架在人工智能和机器学习项目中的应用

    java 框架在人工智能和机器学习项目中的应用java 框架为 ai/ml 解决方案提供了强大的工具和库,流行的框架包括 tensorflow、pytorch、h2o.ai 和 weka。例如,使用 tensorflow,开发者可以创建图像…

    2025年4月2日
    100
  • Dubbo 在微服务架构中的应用场景与优势?

    微服务最佳选择:dubbo轻量级且高性能的 dubbo 框架是微服务架构的首选,支持多种语言并提供分布式系统开发所需的功能。其优势包括高性能、可扩展性、易用性和庞大的生态系统。在实战中,dubbo 可用于构建分布式系统,通过服务解耦和异构系…

    2025年4月2日
    100
  • java可变参数怎么遍历

    Java的可变参数(变长参数)允许函数接受任意数量的参数。遍历这些参数的语法:for (数据类型 参数名 : 可变参数) { // 遍历可变参数的每个元素} Java 可变参数遍历 Java 中的可变参数(也称为变长参数)允许函数接受任意数…

    2025年4月2日
    100
  • java框架如何赋能人工智能发展?

    java 框架通过以下方式赋能 ai:数据管理和处理:spark、hadoop 和 tensorflow data 用于处理和存储 ai 数据。机器学习和深度学习:tensorflow、scikit-learn 和 opencv 用于构建和…

    2025年4月2日
    100

发表回复

登录后才能评论