热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

python学习笔记——多线程

一、线程和进程进程:电脑同时运行有多个软件,每一个运行的软件程序都是一个进程。线程:每一个应用程序内,有多段程序同时
一、线程和进程

进程:

电脑同时运行有多个软件,每一个运行的软件程序都是一个进程

线程:

每一个应用程序内,有多段程序同时执行,每一段程序就是一个线程

二、python的多线程

Python3 线程中常用的两个模块为:

  • _thread
  • threading(推荐使用)

thread 模块已被废弃。用户可以使用 threading 模块代替。所以,在 Python3 中不能再使用"thread" 模块。为了兼容性,Python3 将 thread 重命名为 "_thread"。

1._thread(新线程要做的事放进函数里)

# coding:utf-8
import _thread# 定义一个函数
def print_time(threadName):for i in range(100):print(threadName, ':', i)'''创建两个线程,并开启两个线程'''
_thread.start_new_thread(print_time, ("Thread-1",))
_thread.start_new_thread(print_time, ("Thread---------2",))'''上面开启的都是子线程,这里是主线程,主线程要是结束,子线程就停止了'''
while 1:pass

结果:

2.threading


2.1threading(新线程要做的事放进类的run方法里)

# coding:utf-8
import threadingclass myThread(threading.Thread):def __init__(self, threadName):threading.Thread.__init__(self)self.threadName = threadNamedef run(self):for i in range(100):print(self.threadName, ':', i)
'''创建两个线程,并开启两个线程'''
m1 = myThread("Thread-1")
m2 = myThread("Thread-2")
m1.start()
m2.start()'''threading这种方式。即使主线程先执行完,程序也不会关闭,需要等子线程执行完'''

2.2threading(新线程要做的事放进函数里)

# coding:utf-8
import threading# 定义一个函数
def print_time(threadName):for i in range(100):print(threadName, ':', i)'''创建两个线程,并开启两个线程'''
t1=threading.Thread(target=print_time,args=("Thread-1",))
t2=threading.Thread(target=print_time,args=("Thread-2", ))
t1.start()
t2.start()'''threading这种方式。即使主线程先执行完,程序也不会关闭,需要等子线程执行完'''

2.3守护线程(setDaemon(True))

子线程设置成守护线程,相当于把子线程设置成主线程的守卫,小弟守卫老大的安全,老大(主线程)结束了,小弟(子线程)也就结束了 

# coding:utf-8
import threading# 为线程定义一个函数
def print_time(threadName):for i in range(100):print(threadName, ':', i)'''创建两个线程'''
t1 = threading.Thread(target=print_time,args=("Thread-1",))
t2 = threading.Thread(target=print_time,args=("Thread-2", ))'''设置守护线程后,主线程结束时,子线程也将立即结束,不再执行。'''
t1.setDaemon(True) #把子进程设置为守护线程,必须在start()之前设置
t2.setDaemon(True) #把子进程设置为守护线程,必须在start()之前设置'''开启两个线程'''
t1.start()
t2.start()

2.4主线程等待子线程结束(join()方法)

# coding:utf-8
import threading# 为线程定义一个函数
def print_time(threadName):for i in range(100):print(threadName, ':', i)'''创建两个线程'''
t1 = threading.Thread(target=print_time,args=("Thread-1",))
t2 = threading.Thread(target=print_time,args=("Thread-2", ))'''设置守护线程后,主线程结束时,子线程也将立即结束,不再执行。'''
# t1.setDaemon(True) #把子进程设置为守护线程,必须在start()之前设置
# t2.setDaemon(True) #把子进程设置为守护线程,必须在start()之前设置'''开启两个线程'''
t1.start()
t2.start()t1.join() # 将自己加入到主线程的级别,执行结束,整个程序才可结束
t2.join() # 将自己加入到主线程的级别,执行结束,整个程序才可结束

2.5多线程共享全局变量

使用 Thread 对象的 Lock 和 Rlock 可以实现简单的线程同步,这两个对象都有 acquire 方法和 release 方法,对于那些需要每次只允许一个线程操作的数据或代码,可以将其操作放到 acquire 和 release 方法之间

acquire 和 release之间的数据或代码,同一时间,只能同时被一个线程占用

不使用线程锁

# coding:utf-8
from threading import Thread,Lock
import timecount = 0
#lock = Lock()#创建锁的锁的对象
def print_time(threadName):global countfor i in range(100):count += 1time.sleep(0.01)#lock.acquire() # 获得使用权print(threadName, ':', count)#lock.release()#释放使用权'''创建两个线程'''
t1 = Thread(target=print_time,args=("Thread-1",))
t2 = Thread(target=print_time,args=("Thread-2", ))
'''开启两个线程'''
t1.start()
t2.start()

结果:(打印语句有可能两个线程都在用,打印混乱)

 


使用线程锁

# coding:utf-8
from threading import Thread,Lock
import timecount = 0
lock = Lock()#创建锁的锁的对象
def print_time(threadName):global countfor i in range(100):count += 1time.sleep(0.01)lock.acquire() # 获得使用权print(threadName, ':', count)lock.release()#释放使用权'''创建两个线程'''
t1 = Thread(target=print_time,args=("Thread-1",))
t2 = Thread(target=print_time,args=("Thread-2", ))
'''开启两个线程'''
t1.start()
t2.start()

结果:

 

=========================

参考来源:

https://www.runoob.com/python3/python3-multithreading.html

https://www.cnblogs.com/luyuze95/p/11289143.html


推荐阅读
author-avatar
锋哥很好
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有