python的线程如何启用和结束_python中的线程threading.Thread()使用详解

1. 线程的概念:

线程,有时被称为轻量级进程(Lightweight Process,LWP),是程序执行流的最小单元。一个标准的线程由线程ID,当前指令指针(PC),寄存器集合和堆栈组成。另外,线程是进程中的一个实体,是被系统独立调度和分派的基本单位,线程自己不拥有系统资源,只拥有一点儿在运行中必不可少的资源,但它可与同属一个进程的其它线程共享进程所拥有的全部资源。

2. threading.thread()的简单使用

2.1 python的thread模块是比较底层的模块,python的threading模块是对thread做了一些包装的,可以更加方便的被使用

import threading

import time

def saySorry():

print("亲爱的,我错了,我能吃饭了吗?")

time.sleep(1)

if __name__ == "__main__":

for i in range(5):

t = threading.Thread(target=saySorry)

t.start() #启动线程,即让线程开始执行

运行结果:

2019121714184459.png

使用说明:

可以明显看出使用了多线程并发的操作,花费时间要短很多

当调用start()时,才会真正的创建线程,并且开始执行

每个线程都有一个唯一标示符,来区分线程中的主次关系

主线程:mainThread,Main函数或者程序主入口,都可以称为主线程

子线程:Thread-x 使用 threading.Thread() 创建出来的都是子线程

线程数量:主线程数 + 子线程数

2.2 主线程会等待所有的子线程结束后才结束

import threading

from time import sleep,ctime

def sing():

for i in range(3):

print("正在唱歌...%d"%i)

sleep(1)

def dance():

for i in range(3):

print("正在跳舞...%d"%i)

sleep(1)

if __name__ == '__main__':

print('---开始---:%s'%ctime())

t1 = threading.Thread(target=sing)

t2 = threading.Thread(target=dance)

t1.start()

t2.start()

#sleep(5) # 屏蔽此行代码,试试看,程序是否会立马结束?

print('---结束---:%s'%ctime())

2019121714184460.png

3.查看线程数量

import threading

from time import sleep,ctime

def sing():

for i in range(3):

print("正在唱歌...%d"%i)

sleep(1)

def dance():

for i in range(3):

print("正在跳舞...%d"%i)

sleep(1)

if __name__ == '__main__':

print('---开始---:%s'%ctime())

t1 = threading.Thread(target=sing)

t2 = threading.Thread(target=dance)

t1.start()

t2.start()

while True:

length = len(threading.enumerate())

print('当前运行的线程数为:%d'%length)

if length<=1:

break

sleep(0.5)

2019121714184461.png

4.线程参数及顺序

4.1 传递参数的方法:

使用args 传递参数 threading.Thread(target=sing, args=(10, 100, 100))

使用kwargs传递参数 threading.Thread(target=sing, kwargs={“a”: 10, “b”:100, “c”: 100})

同时使用 args 和 kwargs 传递参数 threading.Thread(target=sing, args=(10, ), kwargs={“b”: 100,“c”: 100})

4.2 线程的执行顺序

import socket

import threading

import time

def sing():

for i in range(10):

print("------------------------------")

time.sleep(0.5)

def dance():

for i in range(10):

print("-----")

time.sleep(0.5)

if __name__ == '__main__':

# 创建两个子线程

t1 = threading.Thread(target=sing)

t2 = threading.Thread(target=dance)

# 启动子线程

t1.start()

t2.start()

说明:

从代码和执行结果我们可以看出,多线程程序的执行顺序是不确定的。当执行到sleep语句时,线程将被阻塞(Blocked),到sleep结束后,线程进入就绪(Runnable)状态,等待调度。而线程调度将自行选择一个线程执行。上面的代码中只能保证每个线程都运行完整个run函数,但是线程的启动顺序、run函数中每次循环的执行顺序都不能确定。

5. 守护线程

守护线程:如果在程序中将子线程设置为守护线程,则该子线程会在主线程结束时自动退出,设置方式为thread.setDaemon(True),要在thread.start()之前设置,默认是false的,也就是主线程结束时,子线程依然在执行。

5.1 如下代码,主线程已经exit() 【其实并没有真正结束】,子线程还在继续执行

import threading

import time

def test():

for i in range(10):

print("test is run:", i)

time.sleep(1)

if __name__ == '__main__':

# 创建子线程

t1 = threading.Thread(target=test)

# 启动子线程

t1.start()

# 休眠2秒

time.sleep(2)

print("我 OVER 了")

# 退出

exit()

2019121714184462.png

5.2 设置守护线程

设置为守护线程(如果主线程结束了,也随之结束)

线程.setDaemon(True)

2019121714184463.png

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

本文标题: python中的线程threading.Thread()使用详解

本文地址: http://www.cppcns.com/jiaoben/python/293406.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python ,多线程编程是很常见的操作。但是多线程编程必然涉及到对共享资源的读写操作,而这很容易引起竞争条件,从而导致数据的不一致性。为了解决这个问题,Python 提供了 Lock 和 RLock 两种锁机制。 1. Lock Lock 是最简单的锁机制,也是最常用的锁机制。它通过 acquire() 方法获得锁,通过 release() 方法释放锁。当一个线程获得了锁,其他线程就不能再获得这个锁,直到这个线程释放锁为止。 下面是一个简单的例子: ```python import threading lock = threading.Lock() def func(): lock.acquire() print('Hello, world!') lock.release() t = threading.Thread(target=func) t.start() ``` 这个例子,首先创建了一个 Lock 对象,然后定义了一个 func 函数,在函数先获得锁,然后输出一句话,最后释放锁。在创建一个线程并执行这个函数时,输出的结果是: ``` Hello, world! ``` 在这个例子,只有一个线程获得了锁,其他线程不能再获得这个锁,所以输出的结果只有一行。 2. RLock RLock 是可重入锁,它可以被一个线程多次 acquire(),而不会发生死锁。这个锁机制可以用在递归函数,因为递归函数可能会多次调用自身。 下面是一个简单的例子: ```python import threading lock = threading.RLock() def func(): lock.acquire() print('Hello, world!') lock.acquire() print('Hello, again!') lock.release() lock.release() t = threading.Thread(target=func) t.start() ``` 这个例子,首先创建了一个 RLock 对象,然后定义了一个 func 函数,在函数先获得锁,输出一句话,再次获得锁,输出另一句话,最后释放锁。在创建一个线程并执行这个函数时,输出的结果是: ``` Hello, world! Hello, again! ``` 在这个例子,虽然 func 函数多次获得了锁,但是由于使用的是可重入锁,所以不会发生死锁,输出的结果也是正确的。 总结: Lock 和 RLock 都是 Python 常用的锁机制,Lock 是最简单的锁机制,而 RLock 是可重入锁,可以在递归函数使用。在多线程编程使用这两个锁机制可以有效地避免竞争条件,保证数据的一致性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值