一、线程和进程
进程:
电脑同时运行有多个软件,每一个运行的软件程序都是一个进程。
线程:
每一个应用程序内,有多段程序同时执行,每一段程序就是一个线程。
二、python的多线程
Python3 线程中常用的两个模块为:
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