代码创建进程和线程的两种方式

"""
定心丸:Python创建进程和线程的方式基本都是一致的,包括其中的调用方法等,学会一个
另一个自然也就会了。
"""
1.创建进程的两种方式
  • 方式一

    import os
    import time
    from multiprocessing import Process # 实例化一个multiprocessing.Process的对象,并传入一个初始化函数对象
    def task(name):
    print(f'进程 {name} 的PID为{os.getpid()},父进程ID为 {os.getppid()}')
    time.sleep(2)
    print(f'进程 {name} 的PID为{os.getpid()} 运行结束') if __name__ == '__main__':
    # 此处要注意,windows下开启进程一定要在main方法下开启
    process1 = Process(target=task, args=('1',))
    process2 = Process(target=task, args=('2',))
    # 启动进程
    process1.start() # 告诉操作系统帮你创建一个进程
    process2.start()
    print(f'主进程 {os.getpid()}')
  • 方式二

    import os
    import time
    from multiprocessing import Process # 继承类的方式去创建
    class MyProcess(Process):
    def __init__(self, name):
    # 继承Process中的__init__()
    super(MyProcess, self).__init__()
    self.name = name # 此处必要在该类中创建run方法 重写run方法
    def run(self):
    print(f'进程 {self.name} 的PID为{os.getpid()},父进程ID为 {os.getppid()}')
    time.sleep(2)
    print(f'进程 {self.name} 的PID为{os.getpid()} 运行结束') if __name__ == '__main__':
    # 创建两个进程
    process1 = MyProcess('1')
    process2 = MyProcess('2')
    # 开启这两个进程
    process1.start()
    process2.start()
    print(f'主进程 {os.getpid()}')

    运行结果如下:

    """
    主进程 2776
    进程 1 的PID为9364,父进程ID为 2776
    进程 2 的PID为4140,父进程ID为 2776
    进程 1 的PID为9364 运行结束进程 2 的PID为4140 运行结束
    """
2.创建线程的两种方式
  • 方式一

    import time
    from threading import Thread # 实例化一个multiprocessing.Process的对象,并传入一个初始化函数对象
    def task(name):
    print(f"线程 {name} is running")
    time.sleep(2)
    print(f"线程 {name} is over") if __name__ == '__main__':
    # 开启线程不需要在main下面执行代码,直接书写就可以
    # 但是还是习惯性的将启动命令写在main下面 # 创建两个线程
    thead1 = Thread(target=task, args=('1',))
    thead2 = Thread(target=task, args=('2',))
    # 开启两个线程
    thead1.start() # 创建线程的开销非常小,几乎代码一执行线程就创建了
    thead2.start()
    print("主")
  • 方式二

    import time
    from threading import Thread # 继承类的方式去创建
    class MyThead(Thread):
    def __init__(self, name):
    # 继承Process中的__init__()
    super(MyThead, self).__init__()
    self.name = name # 此处必要在该类中创建run方法 重写run方法
    def run(self):
    print(f"线程 {self.name} is running")
    time.sleep(2)
    print(f"线程 {self.name} is over") if __name__ == '__main__':
    # 创建两个线程
    thead1 = MyThead('1')
    thead2 = MyThead('1')
    # 开启这两个线程
    thead1.start()
    thead2.start()
    print('主')
  • 输出结果为如下:

    """
    线程 1 is running

    线程 2 is running
    线程 1 is over线程 2 is over
    """

上方只是简单的创建进程和线程,以上注释只是个人理解,不足的地方还望见谅,欢迎补充

Python创建进程、线程的两种方式的更多相关文章

  1. python 之 并发编程(线程理论,开启线程的两种方式,进程与线程的区别,线程对象的其他方法)

    9.9 线程理论 1.什么是线程 线程指的是一条流水线的工作过程 进程根本就不是一个执行单位,进程其实是一个资源单位,一个进程内自带一个线程,线程才是执行单位 2.进程VS线程 同一进程内的线程们共享 ...

  2. 并发编程 - 线程 - 1.开启线程的两种方式/2.进程与线程的区别/3.Thread对象的其他属性或方法/4.守护线程

    1.开启线程的两种方式: 进程,线程: 进程只是用来把资源集中到一起(进程只是一个资源单位,或者说资源集合)而线程才是cpu上的执行单位) 1.同一个进程内的多个线程共享该进程内的地址资源 2.创建线 ...

  3. Python 35 线程(1)线程理论、开启线程的两种方式

    一:线程理论 1 什么是线程 进程其实一个资源单位,而进程内的线程才是cpu上的执行单位 线程其实指的就是代码的执行过程2 为何要用线程   线程vs进程     1. 同一进程下的多个线程共享该进程 ...

  4. 【java并发】传统线程技术中创建线程的两种方式

    传统的线程技术中有两种创建线程的方式:一是继承Thread类,并重写run()方法:二是实现Runnable接口,覆盖接口中的run()方法,并把Runnable接口的实现扔给Thread.这两种方式 ...

  5. 创建线程的两种方式比较Thread VS Runnable

    1.首先来说说创建线程的两种方式 一种方式是继承Thread类,并重写run()方法 public class MyThread extends Thread{ @Override public vo ...

  6. python 并发编程 多线程 开启线程的两种方式

    一 threading模块介绍 multiprocess模块的完全模仿了threading模块的接口,二者在使用层面,有很大的相似性 二 开启线程的两种方式 第一种 每造一个进程,默认有一个线程,就是 ...

  7. Java并发基础01. 传统线程技术中创建线程的两种方式

    传统的线程技术中有两种创建线程的方式:一是继承Thread类,并重写run()方法:二是实现Runnable接口,覆盖接口中的run()方法,并把Runnable接口的实现扔给Thread.这两种方式 ...

  8. Java新建线程的两种方式

    Java新建线程有两种方式,一种是通过继承Thread类,一种是实现Runnable接口,下面是新建线程的两种方式. 我们假设有个竞赛,有一个选手A做俯卧撑,一个选手B做仰卧起坐.分别为两个线程: p ...

  9. 1.java多线程_实现线程的两种方式

    1.java多线程基本知识 1.1.进程介绍 不管是我们开发的应用程序,还是我们运行的其他的应用程序,都需要先把程序安装在本地的硬盘上.然后找到这个程序的启动文件, 启动程序的时候,其实是电脑把当前的 ...

随机推荐

  1. Knn和K-means

    先开个标题,以后慢慢填充. k近邻算法(knn)属于监督学习 一. 三个关键点:1.k的取值,当k值较小时,选取点较少,相当于会有在较小的范围内进行学习预测,学习误差会减小,但是估计误差会增大,因为训 ...

  2. 日志套餐篇 - log4j2 logback全量套餐

    日志套餐篇 - log4j2 logback全量套餐 前情提要: Log4j Log4j2 logback是当下主流的日志框架 slf4j则是新一代的日志框架接口,logback直接实现了slf4j接 ...

  3. 「从零单排canal 05」 server模块源码解析

    基于1.1.5-alpha版本,具体源码笔记可以参考我的github:https://github.com/saigu/JavaKnowledgeGraph/tree/master/code_read ...

  4. Laravel 5.4 使用 Mail 发送邮件获取验证码功能(使用的配置邮箱为126邮箱)

    <?php namespace App\Modules\Liveapi\Http\Controllers\Personnel; use App\Modules\Liveapi\Http\Cont ...

  5. [spring] -- 设计模式篇

    工厂模式 Spring使用工厂模式可以通过 BeanFactory 或 ApplicationContext 创建 bean 对象. BeanFactory :延迟注入(使用到某个 bean 的时候才 ...

  6. Oracle对表进行备份

    前言: 在实际开发中,我们常常需要对单张或多张表进行备份,以下博主就从这两个方面进行总结.如需转载,请标明来处,谢谢! 在备份前我们先创建表盒相关测试的数据 -- Create table creat ...

  7. vue-watch : 深度监控的语法格式--检测数据的tabledata这个数组的变化

    watch:{ tableData:{ handler(a,b){ this.tableData= a; console.log(a ,b) }, deep:true }, }

  8. Monster Audio 使用教程 (八) Vst3 使用侧链功能

    Monster Audio对 Vst3 插件支持侧链功能,例如,我们插入一个Waves C1 comp Stereo 效果器 然后在侧链处,就可以选择任意一个音轨的信号,作为侧链信号源. 注意,只有v ...

  9. Huffuman树--------找最值学会用sort和cmp

    问题描述 Huffman树在编码中有着广泛的应用.在这里,我们只关心Huffman树的构造过程. 给出一列数{pi}={p0, p1, …, pn-1},用这列数构造Huffman树的过程如下: 1. ...

  10. linux dig 命令使用

    linux dig 命令使用方法 2018.04.20 15:47 43101浏览   dig 命令主要用来从 DNS 域名服务器查询主机地址信息. 查询单个域名的 DNS 信息 dig 命令最典型的 ...