首页 > 编程语言 >Python中的多线程

Python中的多线程

时间:2022-10-18 12:00:56浏览次数:47  
标签:__ Thread Python threading 线程 time print 多线程

线程和进程

  1. 线程是程序执行的最小单位,而进程是操作系统分配资源的最小单位
  2. 一个进程由一个或多个线程组成,线程是一个进程中代码的不同执行路线
  3. 进程之间相互独立,但同一线程下的各个线程之间共享程序的内存空间(包括代码段,数据集,堆等)及一些进程级的资源(如打开文件和信号等),某进程内的线程在其他进程中不可见
  4. 线程上下文切换比进程上下文切换要快的多

创建多线程

方法1:

调用threading库的Thread类:

def test(x):
	print(x)
	time.sleep(2)
	
t1 = threading.Thread(target=test,args=(1,))
t2 = threading.Thread(target=test,args=(2,))
t1.start()
t2.start()

方法2:

以继承于Thread类的方式:

cLass MyThread(threading.Thread):
	def__ init__ (seLf, n):
		super (MyThread, seLf).__ init__()
		self.n = n
	def run(self):
		print('以类的方式创建多线程',self.n)
		time.sleep(3)
r1 = MyThread(1)
r2 = MyThread(2)
r1.start()
r2.start()

一些常用方法

查看活动的线程数:threading.active_count() 查看当前线程:threading.current_thread()

守护线程

使用setDaemon(True)把所有的子线程都变成了主线程的守护线程, 因此当主线程结束后,子线程也会随之结束,所以当主线程结束后,整个程序就退出了。 所谓’线程守护’,就是主线程不管该线程的执行情况,只要是其他子线程结束且主线程执行完毕,主线程都会关闭。也就是说:主线程不等待该守护线程的执行完再去关闭

def run(n):
    print('task',n)
    time.sleep(2)
    print('5s')
    time.sleep(2)
    print('3s')
    time.sleep(2)
    print('1s')
    
if __name__ == '__main__':
    t=threading.Thread(target=run,args=('t1',))
    t.setDaemon(True)    #把子线程设置为守护线程,必须在start()之前设置
    t.start()
    t.join()     #设置主线程等待子线程结束
    print('end')

线程锁

由于线程之间是进行随机调度,并且每个线程可能只执行n条执行之后,当多个线程同时修改同一条数据时可能会出现脏数据,所以出现了线程锁,即同一时刻允许一个线程执行操作。 由于线程之间是进行随机调度的,如果有多个线程同时操作一个对象,如果没有很好地保护该对象,会造成程序结果的不可预期,我们因此也称为“线程不安全”。 为了防止上面情况的发生,就出现了线程锁(Lock)

def work():
    global n
    lock.acquire()
    temp = n
    time.sleep(0.1)
    n = temp-1
    lock.release()
    
if __name__ == '__main__':
    lock = Lock()
    n = 100
    l = []
    for i in range(100):
        p = Thread(target=work)
        l.append(p)
        p.start()
    for p in l:
        p.join()

递归锁

递归锁:RLcok类的用法和Lock类一样,支持嵌套,在多个锁没有释放的时候一般会使用RLock类

def func(lock):
    global gl_num
    lock.acquire()
    gl_num += 1
    time.sleep(1)
    print(gl_num)
    lock.release()

if __name__ == '__main__':
    gl_num = 0
    lock = threading.RLock()
    for i in range(10):
       t = threading.Thread(target=func,args=(lock,))
       t.start()

实例:

在一个线程中,每秒循环输出当前的年月日时分秒 于此同时,在另一个线程中,实现张三的姓名每2秒打印输出4次结束。 注意:都需要使用类和继承实现功能

import threading
import time

class MyThread1(threading.Thread):
    def run(self):
        while (True):
            localetime = time.asctime(time.localtime(time.time()))
            print(localetime)
            time.sleep(1)

class MyThread2(threading.Thread):
    def __init__(self,name):
        super(MyThread2, self).__init__()
        self.name=name

    def run(self):
        for i in range(4):
            print(self.name)
            time.sleep(2)

if __name__ == '__main__':

    mt1 = MyThread1()
    mt2 = MyThread2("张三")
    mt2.start()
    mt1.start()

标签:__,Thread,Python,threading,线程,time,print,多线程
From: https://blog.51cto.com/u_15623229/5765724

相关文章

  • 【python】__init__.py文件到底是什么?
    __init__.py作用就是整个文件夹一个包来管理,每当有外部import的时候,就会自动执行里面的函数。1.概述在python中经常能看到__init__.py文件,似乎没什么用的样子,有的时候甚......
  • Python常用库
    一、python爬虫常用库Python在编写网络爬虫常用到库主要包括urllib、requests、lxml、fake-useragent、bs4(BeautifulSoup)、grab、pycurl、urllib3、httplib2、RoboBrow......
  • 「http代理」Python-Scrapy 代码样例(四)
    http代理使用提示1.http/https网页均可适用2.scrapy不是python原生库,需要安装才能使用:pipinstallscrapy3.在第一级tutorial目录下运行如下命令查看......
  • 「http代理」Python-Scrapy 代码样例(三)
    http代理使用提示1.http/https网页均可适用2.scrapy不是python原生库,需要安装才能使用:pipinstallscrapy3.在第一级tutorial目录下运行如下命令查看......
  • Python创建虚拟环境
    Python创建虚拟环境目录Python创建虚拟环境1命令行下1.1virtualenv1.2创建虚拟环境1.3激活/退出虚拟环境1.4删除虚拟环境1命令行下1.1virtualenvpip3installv......
  • Java 多线程(九)死锁及Lock
    死锁多个线程各自站有一些共享资源,并且互相等待其他线程占有的资源才能运行,而导致两个或者多个线程都在等待对方释放资源,都停止执行的情形,某一个同步块同时拥有“两个......
  • python+clickhouse
    1.关于使用客户端能链接成功而使用代码无法访问clickhouse的问题clikchouse有两种链接方式:http端口默认为8123,tcp默认接口为9000使用客户端链接时用8123端口,而代码中就......
  • 【Python基础学习】第二节 列表操作
    Python基础学习之列表操作1.列表的增,删,改,查1.1列表的增加,常用的方法有:append,extent,incertappend()在列表的最后面增加元素;heros=['马里奥','路易斯','林......
  • python 如何将QueryDict转化为dict | 18
    假设我有以下QueryDict:<QueryDict:{u'num':[0],u'var1':[u'value1',u'value2'],u'var2':[u'8']}>我想要一本这样的字典,例如:{'num':[0],'var1':['value1','value2'......
  • Python基础 字符串方法
    1、字符串首字母大写i="shulei_xiaoxin"S=i.capitalize()print(S)Shulei_xiaoxin2、字符串全部大写或小写i="shuLEI_XIAOxin"S=i.upper()S1=i.lower()......