• 技术文章 >常见问题 >Python常见问题

    python多线程和多进程之间的联系

    2020-12-31 15:21:10原创4236

    QQ截图20201211200416.png

    关于多线程的大概讲解:

    在Python的标准库中给出了2个模块:_thread和threading,_thread是低级模块不支持守护线程,当主线程退出了时,全部子线程都会被强制退出了。而threading是高级模块,用作对_thread进行了封装支持守护线程。在大部分状况下人们只需要采用threading这个高级模块即可。

    关于多进程的大概讲解:

    多进程是multiprocessing模块给出远程与本地的并发,在一个multiprocessing库的采用场景下,全部的子进程全是由一个父进程运行来的,这个父进程变成madter进程,它会管理一系列的对象状态下,如果一旦这个进程退出了,子进程很可能处在一个不稳定的状态下,那么这个父进程尽量要少做事来维持其稳定性

    所以python多线程和多进程的区别如下:

    1. 多线程中,全部子线程的进程号一样;多进程中,不一样的子进程进程号不一样

    2. 线程共享内存空间;进程的内存是独立的

    3. 多线程可以共享全局变量,多进程做不到

    4. 同一个进程的线程之间可以直接交流;2个进程想通信,必须通过一个中间代理来实现

    5. 一个线程可以控制和操作同一进程里的其他线程;但是进程只能操作子进程

    6. 创建新线程很简单;创建新进程需要对其父进程进行一次克隆

    专题推荐:python多线程
    上一篇:Python中字符串与二进制如何相互转换? 下一篇:​Python中complex函数是什么?

    相关文章推荐

    • python多线程中的threading使用技巧• python多线程中的死锁和递归锁用法

    全部评论我要评论

    © 2021 Python学习网 苏ICP备2021003149号-1

  • 取消发布评论
  • 

    Python学习网