Python 线程调用
- 简介:
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)
- 守护进程
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()
Python 线程调用的更多相关文章
- c++线程调用python
c++调用python,底层就似乎fork一个子进程启动一个python的解释器,执行python文件,由于python解释器维护了一个内部状态,所以如果c++程序是多线程,每个线程都调用python ...
- python 线程的调用方式
python 线程的调用方式 #!/usr/bin/env python #-*- coding:utf-8 -*- # author:leo # datetime:2019/5/24 9:44 # ...
- python——线程与多线程进阶
之前我们已经学会如何在代码块中创建新的线程去执行我们要同步执行的多个任务,但是线程的世界远不止如此.接下来,我们要介绍的是整个threading模块.threading基于Java的线程模型设计.锁( ...
- python——线程与多线程基础
我们之前已经初步了解了进程.线程与协程的概念,现在就来看看python的线程.下面说的都是一个进程里的故事了,暂时忘记进程和协程,先来看一个进程中的线程和多线程.这篇博客将要讲一些单线程与多线程的基础 ...
- [python] 线程简介
参考:http://www.cnblogs.com/aylin/p/5601969.html 我是搬运工,特别感谢张岩林老师! python 线程与进程简介 进程与线程的历史 我们都知道计算机是由硬件 ...
- Python线程指南
本文介绍了Python对于线程的支持,包括“学会”多线程编程需要掌握的基础以及Python两个线程标准库的完整介绍及使用示例. 注意:本文基于Python2.4完成,:如果看到不明白的词汇请记得百度谷 ...
- Python线程
原文出处: AstralWind 1. 线程基础 1.1. 线程状态 线程有5种状态,状态转换的过程如下图所示: 1.2. 线程同步(锁) 多线程的优势在于可以同时运行多个任务(至少感觉起来是这样). ...
- Python下调用Linux的Shell命令
有时候难免需要直接调用Shell命令来完成一些比较简单的操作,比如mount一个文件系统之类的.那么我们使用Python如何调用Linux的Shell命令?下面来介绍几种常用的方法: 1. os 模块 ...
- python 线程与进程
线程和进程简介 应用程序和进程以及线程的关系? 一个应用程序里可以有多个进程,一个进程里可以有多个线程 最原始的计算机是如何运行的? CPU是什么?为什么要使用多个CPU? 为什么要使用多线程? 为什 ...
随机推荐
- windows远程访问ubuntu下的jupyter notebook必要配置
0.生成配置文件(一般采用默认) jupyter notebook --generate-config 1.打开ipython, 创建一个密文密码 In [1]: from notebook.auth ...
- split和strip的使用
我觉得都可以进行分隔,但最大的不同就是一个返回list,一个返回字符串 s1 = 'deng ye xun' s1.split() Out[8]: ['deng', 'ye', 'xun'] s1.s ...
- PXE配置手记(Linux)
服务器端:RHEL5(静态IP 192.168.1.101) 源Gentoo系统:服务器上的Gentoo系统就来自于它,编译内核也是在这台机器上执行的 无盘客户端:网卡是 AMD PCnet32 支持 ...
- tomcat与jetty的区别
转载自:https://www.cnblogs.com/fengli9998/p/7247559.html Jetty和Tomcat为目前全球范围内最著名的两款开源的webserver/servlet ...
- Jmeter(十一)_针对响应信息不明确的接口做关联
下午写一个新功能的接口脚本,遇到几个技术问题,现在将解决方案写出来 1:做接口关联的时候,发现接口响应没有可以利用的信息.如下图只返回了一个成功的标识,这样的接口如何与之关联? 通过抓包观察后续的修改 ...
- flask 小入门知识点 2018.12.19
今天听得一脸懵逼,主要因为自己英文底子太差了 不耽误时间了,少总结下,开始复习... 代码: # -*- encoding: utf-8 -*- # 导入重定向模块 , url_for简易寻址跳转,j ...
- Linux IO模式及 select、poll、epoll详解及源码(转)
原文:https://segmentfault.com/a/1190000003063859 我只摘取了其中的epoll代码示例,服务端代码 #define IPADDRESS "127.0 ...
- Razor中的@:和语法
用Razor实现流畅编程 Razor尽量减少编写一个视图模板需要敲入的字符数,实现快速流畅的编程工作流.与大部分模板的语法不同,你不必在HTML中为了明确地标记出服务模块 的开始和结束而中断编程.Ra ...
- jxl(Java Excel API) 使用方法 【1】
// 构建Workbook对象, 只读Workbook对象 // 直接从本地文档创建Workbook // 从输入流创建Workbook Workbook workbook = nul ...
- liferay总结的通用的工具类
在写增删改查的时候,自己动手写了几个通用的工具类,这几个通用的工具类也是基于API写的 第一个是liferay中的分页.跟我们做普通的web开发,分页是一样的首先需要建立一个分页的实体的类 packa ...