python网络编程--线程使用threading
一:线程使用
线程使用有两种方法,一种是直接使用,二是通过继承threading.Thread类使用
二:函数式使用
函数式:调用thread模块中的start_new_thread()函数来产生新线程。语法如下:
thread.start_new_thread ( function, args[, kwargs] )
参数说明:
- function - 线程函数。
 - args - 传递给线程函数的参数,他必须是个tuple类型。
 - kwargs - 可选参数。
 
三:线程模块
Python通过两个标准库thread和threading提供对线程的支持。thread提供了低级别的、原始的线程以及一个简单的锁。
thread 模块提供的其他方法:
- threading.currentThread(): 返回当前的线程变量。
 - threading.enumerate(): 返回一个包含正在运行的线程的list。正在运行指线程启动后、结束前,不包括启动前和终止后的线程。
 - threading.activeCount(): 返回正在运行的线程数量,与len(threading.enumerate())有相同的结果。
 
除了使用方法外,线程模块同样提供了Thread类来处理线程,Thread类提供了以下方法:
- run(): 用以表示线程活动的方法。
 - start():启动线程活动。
 - join([time]): 等待至线程中止。这阻塞调用线程直至线程的join() 方法被调用中止-正常退出或者抛出未处理的异常-或者是可选的超时发生。
 - isAlive(): 返回线程是否活动的。
 - getName(): 返回线程名。
 - setName(): 设置线程名。
 
四:直接使用
# -*- coding:utf-8 -*-
__author__ = 'shisanjun' import threading #导入模块
import time def run(t1):
print("run",t1)
time.sleep(2) t1=threading.Thread(target=run,args=("t1",)) #实例线程对象
t2=threading.Thread(target=run,args=("t2",))
t1.start() #启动线程
t2.start() run("t1")
run("t2")
五:通过继承方式实现
# -*- coding:utf-8 -*-
__author__ = 'shisanjun' import threading
import time class MyThread(threading.Thread):#继承线程 def __init__(self,n,sleep_time):
super(MyThread,self).__init__()
self.n=n
self.sleep_time=sleep_time def run(self): print("start child thread",self.n)
time.sleep(self.sleep_time) if __name__=="__main__":
start_time=time.time()
t1=MyThread("t1",2)
t2=MyThread("t2",4)
t1.start() #子线程并发
t2.start() #子线程并发 t1.join()#等t1子线程执行完
t2.join()#等t2子线程执行完
print("---main finish--",time.time()-start_time)
python网络编程--线程使用threading的更多相关文章
- python网络编程--线程的方法,线程池
		
一.线程的其他方法(Thread其他属性和方法) ident() 获取线程id Thread实例对象的方法 isAlive() 设置线程名 getName() 返回线程名 setName() 设置线程 ...
 - python网络编程--线程(锁,GIL锁,守护线程)
		
1.线程 1.进程与线程 进程有很多优点,它提供了多道编程,让我们感觉我们每个人都拥有自己的CPU和其他资源,可以提高计算机的利用率.很多人就不理解了,既然进程这么优秀,为什么还要线程呢?其实,仔细观 ...
 - python网络编程-线程队列queue
		
一:线程queu作用 Python中,queue是线程间最常用的交换数据的形式. 队列两个作用:一个是解耦,一个是提高效率 二:语法 1)队列的类 class queue.Queue(maxsize= ...
 - python网络编程--线程event
		
一:线程event作用 Python提供了Event对象用于线程间通信,它是线程设置的信号标志,如果信号标志位真,则其他线程等待直到信号结束. Event对象实现了简单的线程通信机制,它提供了设置信号 ...
 - python网络编程--线程锁(互斥锁Mutex)
		
一:为什么需要线程锁 一个进程下可以启动多个线程,多个线程共享父进程的内存空间,也就意味着每个线程可以访问同一份数据,此时,如果2个线程同时要修改同一份数据,会出现什么状况? 很简单,假设你有A,B两 ...
 - python网络编程--线程join和Daemon(守护进程)
		
一:什么情况下使用join join([timeout])调用join函数会使得主调线程阻塞,直到被调用线程运行结束或超时. 参数timeout是一个数值类型,用来表示超时时间,如果未提供该参数,那么 ...
 - python网络编程--线程Semaphore(信号量)
		
一:Semaphore(信号量) 互斥锁 同时只允许一个线程更改数据,而Semaphore是同时允许一定数量的线程更改数据 ,比如厕所有3个坑,那最多只允许3个人上厕所,后面的人只能等里面有人出来了才 ...
 - python网络编程--线程递归锁RLock
		
一:死锁 所谓死锁:是指两个或两个以上的进程或线程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去.此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进 ...
 - python网络编程--线程GIL(全局解释器锁)
		
一:什么是GIL 在CPython,全局解释器锁,或GIL,是一个互斥体防止多个本地线程执行同时修改同一个代码.这把锁是必要的主要是因为当前的内存管理不是线程安全的.(然而,由于GIL存在,其他特性已 ...
 
随机推荐
- 我的shell脚本
			
问题:在ip.lt文件中有600个IP,有3个文档模版,三个文档的名称结构都是“ip+一系列字符串”,要求:1.将600个IP分成3分,以三个模版为基础创建600个文档,名字结构与模版相同:2修改60 ...
 - Linux内核设计第八周学习总结 理解进程调度时机跟踪分析进程调度与进程切换的过程
			
陈巧然 原创作品转载请注明出处 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 一.视频内容 Linux ...
 - Java之Junit和反射
			
Junit,反射 Junit 1.测试的分类: 黑盒测试 : 不需要写代码,给输入值,看程序是否能够输出期望的值. 白盒测试 : 需要进行代码的编写,关注的是程序的具体流程. 2.使用步骤(方法类的命 ...
 - Java中的三目运算符可能出现的问题
			
你真的了解Java中的三目运算符吗? 原创 2018-04-27 刨根问底的 Hollis Hollis Hollis 微信号 hollischuang 功能介绍 一个对Coding有着独特追求的人. ...
 - 野指针(Wild pointer)和悬垂指针(dangling pointer)
			
详细参考如下: Dangling pointer(悬垂指针.迷途指针)和 Wild pointer(野指针) 迷途指针经常出现在混杂使用malloc() 和 free() 库调用: 当指针指向的内存释 ...
 - Service Fabric Cluster Manager
			
作者:潘罡 (Van Pan)@ Microsoft 我们回到Service Fabric最底层的话题,谈谈Service Fabric是怎么工作的. 首先,我们回到下面的文档,看看Service F ...
 - Dockerfile编写注意事项
			
转载自:https://blog.fundebug.com/2017/05/15/write-excellent-dockerfile/ 一.目标 更快的构建速度 更小的Docker镜像大小 更少的D ...
 - Docker入门与应用系列(二)镜像管理
			
1.1 什么是镜像 简单说,Docker镜像是一个不包含Linux内核而又精简的Linux操作系统. 1.2 镜像从哪里来 Docker Hub是由Docker公司负责维护的公共注册中心,包含大量的容 ...
 - Linux Wget 命令实例讲解
			
Linux wget是一个下载文件的工具,它用在命令行下.对于Linux用户是必不可少的工具,尤其对于网络管理员,经常要下载一些软件或从远程服务器恢复备份到本地服务器.如果我们使用虚拟主机,处理这样的 ...
 - P1850 换教室
			
P1850 换教室 现在有一张图, 有 \(v <= 300\) 个节点 你需要从 \(c_{1}\) 到 \(c_{2}\) 到 \(c_{n} (n <= 2000)\) 现在你有 \ ...