python24-多线程和多进程基础

本篇主要讲的是多线程和多进程的一些基础知识,包括并发、并行、进程、线程相关概念以及线程的创建与调用、阻塞线程和守护线程的相关实例操作。希望感兴趣的小伙伴可以坚持看下去同时欢迎提出宝贵的意见让我们一起进步!

01:并发和并行

1)并发逻辑上具备同时处理多个任务的能力。

① 特 点:侧重多个任务交替执行,而多个任务之间有可能还是串行的

② 举 例:比如一个人一把铁锹同时挖三个坑

2)并行物理上在同一时刻执行多个并发任务。

① 特 点:侧重同时执行

② 举 例:比如三个人三把铁锹同时挖三个坑

02:进程和线程

1)进程:运行某个软件就相当于开了一个进程,比如开一个QQ就相当于开了一个进程。

2)线程:在QQ这个进程里,传输文字开一个线程,传语音开一个线程等。

3)注意:一个进程管着多个线程,一个进程有且至少有一个线程

03:线程的创建与调用

1)Thread方法:创建一个线程并且返回线程实例

target值:线程要运行的函数

arges为参数,通过列表和元组来传参。需要注意元组传参如果只有一个元素需要加逗号

2)启动线程实例:线程实例.start

3)获取线程名:线程实例.getName

4)注意事项:

①函数和变量是一样,在python中都是对象。函数可以当参数、当返回值、可以赋值给其他变量

函数作为一个参数传递时,不可以加括号。因为加括号表示执行这个函数,而传参只是使用函数名。

import time,threading
def foo(something):#定义每个线程要运行的函数
    for i in range(3):
        time.sleep(1)#休眠1s来模拟CPU处理很多事情
        print('CPU正在执行:'+something)
def bar(something):
    for i in range(5):
        time.sleep(1)
        print('CPU正在执行:'+something)
t1=threading.Thread(target=foo,args=['看电影'])#生成一个线程实例
t2=threading.Thread(target=bar,args=['听音乐'])
t1.start()#启动线程实例
t2.start()
#总共3个进程:一个主线程(该python文件)+2个子线程
print(t1.getName())#获取线程名
print(t2.getName())
print(threading.main_thread().getName())
03:阻塞主线程(join)

主线程等待子线程结束后再运行

import time,threading
def foo(something):#定义每个线程要运行的函数
    for i in range(3):
        time.sleep(1)#休眠1s来模拟CPU处理很多事情
        print('CPU正在执行:'+something)
def bar(something):
    for i in range(5):
        time.sleep(1)
        print('CPU正在执行:'+something)
t1=threading.Thread(target=foo,args=['看电影'])#生成一个线程实例
t2=threading.Thread(target=bar,args=['听音乐'])
t1.start()#启动线程实例
t2.start()
t1.join()#阻塞主线程,检查t1线程是否执行结束
print(t1.getName())
print(t2.getName())
05:守护线程(setDaemon)

1) 方法特点:与join方法基本相反,必须在start()方法调用之前设置

2)使用场景:主线程完成后,不管子线程是否完成都要和主线程一起退出

3)注意事项:设置守护线程后,主线程不结束子线程也不会结束

#需求:电影结束后音乐自动结束
import time,threading
def foo():
    while True:
        time.sleep(1)
        print('听音乐')
t1=threading.Thread(target=foo)
t1.setDaemon(True)#守护线程:主线程结束子线程也结束
t1.start()
for i in  range(3):
    time.sleep(1)
    print('看电影')
print('电影放映结束!')
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. 简介 用户打开浏览器,其实就是打开了浏览器应用程序。那么什么是程序呢?我们常说浏览器是多线程的,JS 是单线...
    love丁酥酥阅读 3,550评论 0 6
  •   一个任务通常就是一个程序,每个运行中的程序就是一个进程。当一个程序运行时,内部可能包含了多个顺序执行流,每个顺...
    OmaiMoon阅读 1,706评论 0 12
  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,144评论 1 32
  • 一. 操作系统概念 操作系统位于底层硬件与应用软件之间的一层.工作方式: 向下管理硬件,向上提供接口.操作系统进行...
    月亮是我踢弯得阅读 6,009评论 3 28
  • 一、进程和线程 进程 进程就是一个执行中的程序实例,每个进程都有自己独立的一块内存空间,一个进程中可以有多个线程。...
    阿敏其人阅读 2,625评论 0 13