计算机基础知识33

进程基础(操作系统中的概念)

进程它是操作系统总最重要的概念,线程也是

进程和线程都是有操作系统来调度使用的,我们程序员是不能控制的

# 进程和程序是两码事、完全不一样

      程序:其实一个死的东西、一堆代码就是程序,它也没有生命周期

      进程:它是有生命周期的,这个任务做完,进程就不存在了

              # 程序就是流程. 做菜的过程就是进程

                 厨师就是线程,谁干活谁就是线程,做菜完,进程就不存在了

# 一个进程中至少要有一个线程,可以有多个线程

协程就是程序员级别的,协程的调度它就是有我们程序员自己来调度的

          进程 >>> 线程  >>> 协程

          他们三个消耗资源的对比:进程 >>> 线程 >>> 协程

# 单个CPU一次只能运行一个任务,打开浏览器的过程就是进程

进程调度算法(四种算法)

# CPU的工作机制:

         1. 遇到I/O的时候,CPU会交出执行权限
         2. 当CPU遇到耗时比较长的时候,也会自动交出执行权限,切换到其他任务

#  I/O密集型:会被时间所阻塞,不会占用大量的CPU资源,比如sleep(3)

   计算密集型:没有时间的大量消耗,不占用大量的时候,会占用大量的CPU资源

for i in range(10000000):i+=1

一、先来先服务调度算法
二、短作业优先调度算法
三、时间片轮转法(选时间合适的)
四、多级反馈队列

进程的并行和并发概念

并行:统一时刻同时运行

并发:一段时间内看起来是同时运行

          CPU是单核时,同一时刻能不能做到同时执行多个任务,看上去是,来回切换

          CPU4核,执行2个任务,派哪两个核是由操作系统做

"""面试题:你对高并发有什么见解? 聊聊高并发? 你如何解决?"""

同步异步阻塞和非阻塞

# 老师:

       同步:每一次的运行都要依赖于上一步的结果       # 电话不挂,查到告诉
       异步:每次的运行结果不依赖于上次的结果          #  先挂,查到后再打电话告诉

# 我:

        阻塞: # 电话不挂,一直等老师消息
       非阻塞:  # 先干自己的事,没有再打电话给老师询问消息

异步+非阻塞 # 是效率最高的
                    同步+阻塞   # 是效率最低的 

如何开启进程

from multiprocessing import Processdef task():with open('a.txt', 'w', encoding='utf-8') as f:f.write('helloworld')if __name__ == '__main__':p = Process(target=task)  #   实例出来一个进程类, 让这个进程执行task任务p.start()    # 真正的开启进程

# 开启一个进程来执行task任务,真正执行的是线程,进程里面至少有一个线程

# 操作系统开启进程

Process类的参数

进程的几个属性:1、进程名   2、进程号pid   kill

# 查看就进程名称      print( p.name)

# 改进程名字

p.name = '这是新的进程名'
print(p.name)  # 这是新的进程名

# 传参

from multiprocessing import Process
import timedef task(name, age, gender):time.sleep(3)print("子进程的代码")if __name__ == '__main__':# 只是通知操作系统去开进程,有一定时间,开启进程其实消耗很大p = Process(target=task, name='process-2')   # 子进程p.start()  # 启动进程

# 查看进程号:print(p.pid) # process id

task任务里都是子进程,其余是主进程

           p.start()  # 真正的开启进程

           p.terminate() # 杀死进程,结束任务

           print(p.is_alive())   # True 看进程是否还在

           p.join() # 等待子进程的代码全部执行完毕,在走主进程的

单进程

如何开启多进程

多进程就意味着可以同时做多个任务

from multiprocessing import Process
import timedef task(name):with open('a.txt', 'a', encoding='utf-8') as f:f.write('helloworld')if __name__ == '__main__':for i in range(5):     # 执行5次p=Process(target=task, kwargs={'name':'kevin'})p.start()    

# 理论上可以一直开进程,但是需要考虑资源的消耗情况

       # 先执行主进程,再执行子进程

多进程中,想先执行子进程再主进程,p.join(),不能加在for循环中,不然是5秒

from multiprocessing import Process
import timedef task(name):print("子进程")time.sleep(1)if __name__ == '__main__':start_time = time.time()ll = []for i in range(10):p=Process(target=task, kwargs={'name':'kevin'})p.start()ll.append(p)for j in ll:        # 小的高并发情况,双11同时涌进大量客户j.join()print("主进程, 总时间:", time.time() - start_time)

基于TCP协议的高并发程序

一个服务端不能够同时给多个客户端发送消息

import socket  # python提供的socket模块def task(conn):while True:try:data = conn.recv(1024)  # 括号里面写的是接收的字节数,最多接收1024个字节if len(data) == 0:continueprint(data)  # 还是bytes类型conn.send(data.upper())    # 服务端开始给客户端也发送一个数据except Exception as e:print(e)breakconn.close()from multiprocessing import Processif __name__ == '__main__':server = socket.socket()  # 默认是TCP协议server.bind(('127.0.0.1', 8001))  # 服务端绑定一个地址server.listen(1)  # 监听,半连接池print('服务端正在准备接收客户端消息:')while True:conn, client_addr = server.accept()  # 接收,  程序启动之后,会在accept这里夯住,阻塞p = Process(target=task, args=(conn,))p.start()

今日思维导图: 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/109088.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

视频推拉流/直播点播平台EasyDSS分享的链接提示“无信号”,该如何解决?

视频直播点播平台EasyDSS可支持用户自行上传视频文件,也可将上传的点播文件作为虚拟直播进行播放。平台能支持多屏播放,可兼容Windows、Android、iOS、Mac等操作系统,还能支持CDN转推,具备较强的可拓展性与灵活性。 为给用户提供更…

Git 提交规范

遇到的问题 在项目中采用 git 管理代码版本时,突然不能进行提交(git commit)。 报错信息如下: ERROR invalid commit message format. Proper commit message format is required for automated changelog generation. Git 规范…

AI 浪潮下的创业故事(一)—— Jina AI

点击蓝字 关注我们 编辑:Alan Wang 排版:Rani Sun 微软 Reactor 为帮助广开发者,技术爱好者,更好的学习 .NET Core, C#, Python,数据科学,机器学习,AI,区块链, IoT 等技术&#xff0…

CentOS7 内核升级

1.linux内核版本说明 https://en.wikipedia.org/wiki/Linux_kernel_version_history The Linux Kernel Archives - Releases

Mobpush智能化精准推送,助力求职者快人一步

近日,“BOSS”直聘崩了的消息又又又上了热搜,2023年9月15日上午,BOSS直聘在线统计超过4700万人。由此可见,随着金九银十招聘旺季的到来,求职软件成为人们的青睐。但是对于大多数使用招聘软件的用户而言,往往…

unigui点击按钮后弹出悬浮窗,几秒钟后关闭

为了实现点击按钮后,复制内容到剪切板,然后弹出悬浮窗提示给用户。 js代码如下,复制内容,然后保存命名为.js的文件: //弹窗提醒function showAlert(s_msg) {// 创建 div 元素var div document.createElement("d…

【算法训练-排序算法 三】【排序应用】合并区间

废话不多说,喊一句号子鼓励自己:程序员永不失业,程序员走向架构!本篇Blog的主题是【合并区间】,使用【数组】这个基本的数据结构来实现,这个高频题的站点是:CodeTop,筛选条件为&…

【vr】【unity】白马VR课堂系列-VR开发核心基础05-主体设置-手柄对象的引入和设置

【视频教学】 【白马VR课堂系列-VR开发核心基础05-主体设置-手柄对象的引入和设置】 https://www.bilibili.com/video/BV19D4y1N73i/?share_source=copy_web&vd_source=7f5c96f5a58b7542fc6b467a9824b04e 【内容】 上一节引入了XR Origin并进行了初步设置,运行测试时V…

基于主动移频法与AFD孤岛检测的单相并网逆变器matlab仿真

微❤关注“电气仔推送”获得资料(专享优惠) 仿真模型 算法介绍 (1)仿真模型由单相电网、逆变器、滤波环节、PI控制器、PWM生成器、锁相环、AFD控制器s函数、测量模块等构成; (2)采用主动移频法(AFD)进行孤岛检测; (3)相应速度…

基于springboot实现汉服文化分享平台项目【项目源码+论文说明】

摘要 本论文主要论述了如何使用JAVA语言开发一个汉服文化平台网站 ,本系统将严格按照软件开发流程进行各个阶段的工作,采用B/S架构,面向对象编程思想进行项目开发。在引言中,作者将论述汉服文化平台网站的当前背景以及系统开发的…

【vue2高德地图api】02-npm引入插件,在页面中展示效果

系列文章目录 提示:写完文章后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 系列文章目录前言一、安装高德地图二、在main.js中配置需要配置2个key值以及1个密钥 三、在页面中使用3.1 新建路由3.2新建vue页面3.2-1 index.vue3.2…

基于RuoYi-Flowable-Plus的若依ruoyi-nbcio支持自定义业务表单流程的集成方法与步骤(一)

更多ruoyi-nbcio功能请看演示系统 gitee源代码地址 前后端代码: https://gitee.com/nbacheng/ruoyi-nbcio 演示地址:RuoYi-Nbcio后台管理系统 由于大家最自定义业务表单的整个集成方法还不熟悉,下面大概介绍一下这个流程与方法。 1、首先…

2.2 如何使用FlinkSQL读取写入到文件系统(HDFS\Local\Hive)

目录 1、文件系统 SQL 连接器 2、如何指定文件系统类型 3、如何指定文件格式 4、读取文件系统 4.1 开启 目录监控 4.2 可用的 Metadata 5、写出文件系统 5.1 创建分区表 5.2 滚动策略、文件合并、分区提交 5.3 指定 Sink Parallelism 6、示例_通过FlinkSQL读取kafk…

【MySQL】索引介绍、索引的数据结构

🐌个人主页: 🐌 叶落闲庭 💨我的专栏:💨 c语言 数据结构 javaEE 操作系统 Redis 石可破也,而不可夺坚;丹可磨也,而不可夺赤。 索引 一、索引概述二、索引结构2.1 BTree2.…

【论文阅读】 Cola-Dif; An explainable task-specific synthesis network

文章目录 CoLa-Diff: Conditional Latent Diffusion Model for Multi-modal MRI SynthesisAn Explainable Deep Framework: Towards Task-Specific Fusion for Multi-to-One MRI Synthesis CoLa-Diff: Conditional Latent Diffusion Model for Multi-modal MRI Synthesis 论文…

使用vscode + vite + vue3+ element3 搭建vue3脚手架

技术栈 开发工具:VSCode 代码管理:Git 前端框架:Vue3 构建工具:Vite 路由:vue-router 状态管理:vuex AJAX:axios UI库:element-ui 3 数据模拟:mockjs css预处理&#xf…

Three.js图案溶解shader

上图提供两种方式溶解显示 上面一排是根据现实的图案红色通道也就是r值进行溶解 下面一排提供额外的溶解纹理 可以通过简单更改呈现多种溶解图案 代码仓库 gitee b站账号:https://space.bilibili.com/374230437 interface IMapPath {map: string;dissolve?: string…

3-k8s-镜像仓库harbor搭建

文章目录 一、概念二、安装harbor三、使用harbor仓库 一、概念 官方概念:Harbor是一个用于存储和分发Docker镜像的企业级Registry服务器。 我们平时拉去镜像都是从线上仓库拉去,但是企业内部的镜像一般都不会随意传到网上,而是保存在自己公…

基于springboot实现酒店管理系统平台项目【项目源码+论文说明】计算机毕业设计

摘要 21世纪的今天,随着社会的不断发展与进步,人们对于信息科学化的认识,已由低层次向高层次发展,由原来的感性认识向理性认识提高,管理工作的重要性已逐渐被人们所认识,科学化的管理,使信息存…

如何优化模型渲染性能

1、提高模型渲染性能的好处 优化模型渲染性能有以下几个好处: 提高用户体验:良好的模型渲染性能可以使图形应用程序更加流畅和响应快速。当模型以较高的帧率渲染时,用户可以获得更流畅、更真实的视觉效果,提升整体的用户体验。 …