zoukankan      html  css  js  c++  java
  • 多线程,多进程使用场景

    既然有GIL锁,为什么还使用多线程?

          CPU运行程序的时候,从内存中读取数据块,但是内存不支持断电保存的功能。一旦断电,数据就会丢失。所以需要把数据存到物理磁盘中,所以CPU运行程序的时候需要先从磁盘中读出来,放到内存中,CPU才能取到数据。磁盘的读取比较慢,CPU在物理磁盘中取数据时,需要等待磁盘准备数据,什么时候数据准备好了,CPU才能使用数据,这样造成了资源的浪费,写数据是一样的,当CPU往磁盘写入数据的时候就会等待,等数据存入到磁盘中了CPU才能执行别的程序。造成了CPU空闲阻塞状态,如果有大量的IO操作,就会频繁出现阻塞行为,那么GIL锁就会自动被释放,这样就会保证多线程同时运行的效果,虽然不是全部的。一跳主线运行的时候,大概运行了100条指令的时候就会释放GIL锁,或者出现阻塞的时候就会释放GIL锁。

    多线程的应用场景:

            CPU密集型的程序,整个程序运行中过程中不需要等待任何的IO操作,只有大量的CPU进行运算,这种线程不合适,进程实现更加合适,因为每个进程中都有一个线程,独享一个GIL锁,这样就不涉及抢的问题了,各自运行各自的程序。所以进程实现更加合适、

    协程的使用场景:

            协程内部是线程内容划分的更小的单位,协程跟操作系统没有关系,只是程序员自己划分出来的,类似于一个线程中的一跳主线中的两个函数交替运行,达到同时运行的效果,用yield关键字可以让函数暂停下来,next()函数可以让程序继续运行,互相配合达到了协程的效果,上下文切换快速,不需要竞争资源,一条主线。

  • 相关阅读:
    WebRTC之完整搭建Jitsi Meet指南
    使用Jibri进行Jitsi Meet视频录制
    完整开源免费视频会议Jitsi-meet安装教程
    iOS聊天起泡(背景图片被拉伸不变形)----转载--待验证
    技术人对赚钱的思考与摸索
    模板引擎的思考
    SpringBoot单文件与多文件上传
    数据库被删之反思
    分布式配置中心之思考
    正版office产品密钥-激活码
  • 原文地址:https://www.cnblogs.com/zhangshuyang/p/8064899.html
Copyright © 2011-2022 走看看