python-阻塞线程和守护线程(同步锁)

一、线程的创建

【1】threading.Thread创建一个线程,返回一个对象,用变量接收

【2】变量.start启动线程

# -*- coding:utf-8 -*-
# __author__:
# 2022/5/10

# GIL:全局解释器锁,只允许 同一时间只允许1个线程进入CPU,所以cpython中没有并行,是并发
import threading,time

def foo(st):
    for i in range(5):
        time.sleep(1)
        print(st)

# 1、threading.Thread创建一个线程,返回一个对象
# 2、args入参是个元祖,所以括号最后要加上逗号;入参即foo函数的入参
# 3、target是目标函数
t1 = threading.Thread(target=foo,args=('消费数据1',))
t2 = threading.Thread(target=foo,args=('消费数据2',))

# 启动线程
t1.start()
t2.start()

【3】以上代码最终结果是, '消费数据1'和'消费数据2'和换行符,并发进行,执行完后结束

二、阻塞线程join

【1】join阻塞父线程:在子线程没有执行完成之前,阻塞父线程;当子线程全都执行完成后,继续执行父线程

# -*- coding:utf-8 -*-
# __author__:
# 2022/5/10

import threading

def foo(st):
    for i in range(5):
        print(st)

t1 = threading.Thread(target=foo,args=('生产数据1',))
t2 = threading.Thread(target=foo,args=('生产数据2',))

t1.start()
t2.start()

# join阻塞父线程:在子线程没有执行完成之前,阻塞父线程;当子线程全都执行完成后,继续执行父线程
# 运行.py文件的时候,.py文件的代码运行相当于主(父)线程,两个创建的t1t2相当于子线程
t1.join()
t2.join()

# 父线程中的代码
print('继续执行父线程')

【2】以上代码运行结果是:当t1和t2的并发线程结束后,才会执行主线程中的print语句

三、守护线程daemon

【1】当没有守护线程的时候,如果主线程运行完毕,此时子线程还没运行结束,则主线程会等所有子线程运行完毕后再结束
【2】当有守护线程的时候,如果主线程运行完毕,子线程还没运行完毕,则主线程仍会结束,不会等待子线程
【3】 声明守护线程,必须在线程start启动之前

# -*- coding:utf-8 -*-
# __author__:pansy
# 2022/5/10
import threading

def foo(st):
    for i in range(5):
        print(st)

t1 = threading.Thread(target=foo,args=('消费数据1',))
t2 = threading.Thread(target=foo,args=('消费数据2',))

# 当没有守护线程的时候,如果主线程运行完毕,此时子线程还没运行结束,则主线程会等所有子线程运行完毕后再结束
# 当有守护线程的时候,如果主线程运行完毕,子线程还没运行完毕,则主线程仍会结束,不会等待子线程
# 声明守护线程,必须在线程start启动之前
t1.daemon = True
t2.daemon = True

t1.start()
t2.start()

print('消费数据结束。。。。。')

【4】以上代码的结果是:当出现打印'消费数据结束。。。。。'时,表示主线程结束,不会等待子线程,此时不会继续打印'消费数据1'和'消费数据2'

posted on 2022-05-10 23:24  墙角一枝花  阅读(354)  评论(0编辑  收藏  举报