• 简介:

  Python 线程可以通过主线程,调用线程来执行其他命令,

  为Python提供更方便的使用。  

  • 并发线程测试
# 命令调用方式
import threading,time # 定义每个线程要运行的函数
def run(n):
print("task",n)
time.sleep(1) # 生成一个线程实例target=目标,args=参数
t1 = threading.Thread(target=run,args=("t1",))
t2 = threading.Thread(target=run,args=("t2",)) #启动线程
t1.start()
t2.start()
  • 并发类的继承测试
import threading,time

# 继承threading.Thread
class MyThread(threading.Thread): # 重写父类的构造函数
def __init__(self,n): # 重构构造函数
super(MyThread.self).__init__()
self.n = n # 定义每个线程要运行的函数
def run(self):
print("running task ",self.n) # 实例化
t1 = MyThread("t1")
t2 = MyThread("t2") # 启动线程
t1.start()
t2.start()
  • 实现并发串行执行命令
import threading,time
def run(n):
print("task",n)
time.sleep(1)
start_time = time.time()
for i in range(50):
t = threading.Thread(target=run,args=("t-%s"%i,))
t.start()
t.join() # 注:默认主线程不会等子线程执行完在执行。
# 注:串行:等待前一个命令完全执行完,在执行下一条命令。
# 注:实例.join() #wait() 等待执行完毕执行下条命令,可实现串行。
  • 实现主线程等待子线程执行完毕后在往下执行
import threading,time

# 定义每个线程要运行的函数
def run(n):
print("task",n)
time.sleep(2) # 测试执行结果后的用时时间
start_time = time.time() # 创建列表接收t.start()对象内容。
t_objs = [] # 循环50次
for i in range(3): # 生成一个线程实例target=目标,args=参数
t = threading.Thread(target=run,args=("t-%s"%i,)) # 启动线程 调用run
t.start() # 执行结果添加到列表
t_objs.append(t) # 将每个循环t对象一次进行等待。
for t in t_objs: # 每循环一次等待一次
t.join() # 打印用时时间
print("cost:",time.time() - start_time)
  • 守护进程
守护线程:依赖于主线程存在的,为主线程工作。
  功能:设置成守护线程后,主线程关闭,守护线程也连带关闭。
使用场景:socketserver 每一个链接过来,socketserver就会启动一
     个线程,当服务端关闭时,需要关闭其他线程,就可以用
     到守护线程,关闭。
 
import threading,time

# 定义每个线程要运行的函数
def run(n):
print("task",n)
time.sleep(5) # 创建列表接收t.start()对象内容。
#t_objs = [] # 循环3次
for i in range(3): # 生成一个线程实例target=目标,args=参数
t = threading.Thread(target=run,args=("t-%s"%i,)) # 要在start之前设置
# 把当前线程设置为守护线程
t.setDaemon(True) # 启动线程 调用run
t.start()
注:所有程序执行完毕,还有一个join等待,执行完毕退出程序。
注:主线程MainThread,线程Thread。
 
threading.current_thread() #测试当前活动的线程类型。
threading.active_count() #测试当前活动的线程数。

Python 线程调用的更多相关文章

  1. c++线程调用python

    c++调用python,底层就似乎fork一个子进程启动一个python的解释器,执行python文件,由于python解释器维护了一个内部状态,所以如果c++程序是多线程,每个线程都调用python ...

  2. python 线程的调用方式

    python 线程的调用方式 #!/usr/bin/env python #-*- coding:utf-8 -*- # author:leo # datetime:2019/5/24 9:44 # ...

  3. python——线程与多线程进阶

    之前我们已经学会如何在代码块中创建新的线程去执行我们要同步执行的多个任务,但是线程的世界远不止如此.接下来,我们要介绍的是整个threading模块.threading基于Java的线程模型设计.锁( ...

  4. python——线程与多线程基础

    我们之前已经初步了解了进程.线程与协程的概念,现在就来看看python的线程.下面说的都是一个进程里的故事了,暂时忘记进程和协程,先来看一个进程中的线程和多线程.这篇博客将要讲一些单线程与多线程的基础 ...

  5. [python] 线程简介

    参考:http://www.cnblogs.com/aylin/p/5601969.html 我是搬运工,特别感谢张岩林老师! python 线程与进程简介 进程与线程的历史 我们都知道计算机是由硬件 ...

  6. Python线程指南

    本文介绍了Python对于线程的支持,包括“学会”多线程编程需要掌握的基础以及Python两个线程标准库的完整介绍及使用示例. 注意:本文基于Python2.4完成,:如果看到不明白的词汇请记得百度谷 ...

  7. Python线程

    原文出处: AstralWind 1. 线程基础 1.1. 线程状态 线程有5种状态,状态转换的过程如下图所示: 1.2. 线程同步(锁) 多线程的优势在于可以同时运行多个任务(至少感觉起来是这样). ...

  8. Python下调用Linux的Shell命令

    有时候难免需要直接调用Shell命令来完成一些比较简单的操作,比如mount一个文件系统之类的.那么我们使用Python如何调用Linux的Shell命令?下面来介绍几种常用的方法: 1. os 模块 ...

  9. python 线程与进程

    线程和进程简介 应用程序和进程以及线程的关系? 一个应用程序里可以有多个进程,一个进程里可以有多个线程 最原始的计算机是如何运行的? CPU是什么?为什么要使用多个CPU? 为什么要使用多线程? 为什 ...

随机推荐

  1. Mongodb之主从复制

    本次在同一台主机启动两个端口进行配置 在文件夹/etc/mongod下面新建两个配置文件 一个主配置文件一个从配置文件 master.conf dbpath=/data/mongo-master lo ...

  2. 2018-2019-2 20165330《网络对抗技术》Exp3 免杀原理与实践

    目录 基础问题 相关知识 实验内容 实验步骤 实验过程中遇到的问题 离实战还缺些什么技术或步骤? 实验总结与体会 实验内容 正确使用msf编码器,msfvenom生成如jar之类的其他文件,veil- ...

  3. SQL Fundamentals: 数据更新及事务处理(INSERT INTO,UPDATE,DELETE,事务,锁)

    SQL Fundamentals || Oracle SQL语言 在SQL语句中,数据操作语言DML由两部分组成,查询(DQL).更新操作(增加,修改,删除). 增加数据(INSERT INTO) 数 ...

  4. java重载和重载的区别

    重载 public class A{     public void test(){}     public void test(int num){}     public void test(Str ...

  5. CCCC L2-001 紧急救援 floyd改的dijkstra模板 (记录路径) L3 天梯地图

    https://www.patest.cn/contests/gplt/L2-001 题解:求最短路的条数,并输出点的权值最大的路径,用priority_queue会wa两个点,原因不明. 于是又学了 ...

  6. Python面试网络编程和并发

    1.简述 OSI 七层协议. OSI 开放系统互联参考模型,它是理论的,参考模型 七层:物理层->数据链路层->网络层->传输层->会话层->表示层->应用层 2. ...

  7. Frogger--poj2253

    http://poj.org/problem?id=2253 题意:The frog distance (humans also call it minimax distance) between t ...

  8. nodejs(五)同步异步--BLOCKING THE EVENT LOOP

    1.BLOCKING THE EVENT LOOP Node and JavaScript runtimes in general are single-threaded event loops. O ...

  9. .NET数据挖掘与机器学习开源框架

    1.    数据挖掘与机器学习开源框架 1.1 框架概述 1.1.1 AForge.NET AForge.NET是一个专门为开发者和研究者基于C#框架设计的,他包括计算机视觉与人工智能,图像处理,神经 ...

  10. Saving Princess claire_(hdu 4308 bfs模板题)

    http://acm.hdu.edu.cn/showproblem.php?pid=4308 Saving Princess claire_ Time Limit: 2000/1000 MS (Jav ...