线程的基础-线程和进程、并行与并发

线程和进程的区别,简单理解就是电脑一个完整的任务就是一个进程,一个进程可有多可线程组成,多个线程都是这个任务的组成部分共享资源。

进程是程序在执行过程中的一个实例,它拥有独立的内存空间和系统资源,而线程是进程的一个执行单元,是进程内一个相对独立可调度的实体。程序是由指令和数据组成的,指令运行和数据读写,需将指令加载到CPU,数据加载至内存。指令在运行过程中需要使用到磁盘、网络等设备。进程就是来加载指令、管理内存、管理IO的。一个程序被运行,从磁盘加载这个程序的代码到内存,就开启一个进程。

一个进程之内可以分为一到多个线程。一个线程就是一个指令流,将指令流中的一条条指令以一定的顺序交给CPU执行。java中,线程作为最小的调度单位,进程作为资源分配的最小单位。在windows中进程是不活动的,只是作为线程的容器。线程上下文切换成本一般上要比进程上下文切换低。

总结起来,进程是操作系统分配资源的基本单位,而线程是进程内的执行单元。进程之间相互独立,线程之间共享资源。线程切换开销小,稳定性较差。进程切换开销大,稳定性较好。(由于线程共享进程资源,一个线程崩溃可能导致整个进程的崩溃。进程之间相互独立,进程的崩溃不会影响其他进程)多线程编程中,线程的使用可以提高程序的并发性和响应性。

并行和并发的区别,并发就是单核CPU不断切换线程,并行就是多核CPU的不同核执行不同的线程。

对于单核CPU下线程实际上还是串行执行的。操作系统中有一个组件叫做任务调度器,将cpu的时间片分给不同的程序使用,只是cpu在时间片之间的切换非常快,感觉就是同时运行的,这种线程轮流使用CPU的做法成为并发。而多核CPU每个核都可以调度运行线程,线程是可以并行的。

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

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

相关文章

【C++】强制类型转换

强制类型转换分为显式和隐式 显式直接用小括号强制转换,float b (int)a; 隐式直接 float b 0.5; int a b; C中更推荐用四个强制类型转换的关键字: 1、static_cast, 2、const_cast, 3、reinterpret_cast, 4、dynami…

8 scala的伴生对象

1 单例对象 在编写 Java 程序时,我们经常会通过编写静态方法代码,去封装常用的 Utility 类。 在 Scala 中没有静态成员这一概念,所以,如果我们要定义静态属性或方法,就需要使用 Scala 的单例对象 object。Scala 的对…

Days28 ElfBoard 板]修改开机动画

1.可能需要安装的库 elfubuntu:~/work/psplash$ sudo apt-get install build-essential libncurses5-dev elfubuntu:~/work/psplash$ sudo apt-get install libtool elfubuntu:~/work/psplash$ sudo apt-get install gettext elfubuntu:~/work/psplash$ sudo apt-get install l…

熵与信息量简单理解。

一件事的信息量是啥东西?公式 -log2(P) P是这件事发生的概率 举例:a同学与b同学可以互相通信。双方约定用2进制传递信息。 1.例如:假定a能看到一个随机试验,就是从0-7中任意选一个数。这件事发生抽到了7。 a要把信息传递给b。…

Unity学习笔记(零基础到就业)|Chapter04:C#篇补充到Unity篇过渡

Unity学习笔记(零基础到就业)|Chapter02:C#篇补充到Unity篇过渡 前言C#总结补充1.值类型和引用类型有什么区别,他们在值的传递上分别有怎样的特性2.string是引用类型,但是他对外表现出值类型的特性,为什么&…

【AI大模型应用开发】【LangChain系列】6. LangChain的Callbacks模块:监控调试程序的重要手段

大家好,我是【同学小张】。持续学习,持续干货输出,关注我,跟我一起学AI大模型技能。 LangChain提供了一个回调系统,允许您挂接到LLM应用程序的各个阶段。这对于日志记录、监视、流式传输和其他任务非常有用。 0. Lang…

P1013 [NOIP1998 提高组] 进制位

P1013 [NOIP1998 提高组] 进制位 这破题我理解题解理解了三天……我是不是不适合学计算机 #include <iostream> #include <cstring> #include <unordered_map> // n <8 && n>2 (但是从0开始计数&#xff0c;故最大值是 1~7&#xff0c;最小值…

蓝桥杯每日一题之内存问题

蓝桥杯真题---内存问题 题目描述&#xff1a; 小蓝最近总喜欢计算自己的代码中定义的变量占用了多少内存空间。 为了简化问题&#xff0c;变量的类型只有以下三种&#xff1a; int&#xff1a;整型变量&#xff0c;一个 int 型变量占用 4 Byte 的内存空间。 long&#xff…

Mac中管理多版本Jdk

1. 首先下载JDK&#xff0c;以jdk8和17为例 2. 打开.zprofile中添加如下内容 #java config export JAVA_8_HOME/Library/Java/JavaVirtualMachines/zulu-8.jdk/Contents/Home export JAVA_17_HOME/Library/Java/JavaVirtualMachines/zulu-17.jdk/Contents/Home#default java …

如何在 Ubuntu 16.04 上设置 Jupyter Notebook 来运行 IPython

简介 IPython 是 Python 的交互式命令行界面。Jupyter Notebook 提供了一个交互式的 Web 界面&#xff0c;可以运行多种语言&#xff0c;包括 IPython。 本文将指导您设置一个服务器来运行 Jupyter Notebook&#xff0c;并教您如何连接和使用笔记本。Jupyter 笔记本&#xff…

【快速上手QT】02-学会查看QT自带的手册QT助手

QT助手 为什么大家都说QT简单&#xff0c;第一点就是确实简单&#xff08;bushi&#xff09;。 我个人觉得最关键的点就是人家QT官方就给你准备好了文档&#xff0c;甚至还有专门的IDE——QtCreator&#xff0c;在QTCreator里面还有很多示例代码&#xff0c;只要你会C的语法以…

Top 20 Docker 面试题(附答案)

Docker 是一种流行的开源软件平台&#xff0c;可简化创建、管理、运行和分发应用程序的过程。它使用容器来打包应用程序及其依赖项。Docker 主导了市场。大多数顶级云和 IT 公司都采用 Docker 来简化其应用程序开发工作流程。对具有 Docker 经验的申请人的需求很高。 破解 Doc…

鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之Divider组件

鸿蒙&#xff08;HarmonyOS&#xff09;项目方舟框架&#xff08;ArkUI&#xff09;之Divider组件 一、操作环境 操作系统: Windows 10 专业版、IDE:DevEco Studio 3.1、SDK:HarmonyOS 3.1 二、Divider组件 提供分隔器组件&#xff0c;分隔不同内容块/内容元素。 子组件 …

C#使用重载方法实现不同类型数据的计算

目录 一、涉及到的相关知识 1.重载的方法 2.Convert.ToInt32(String)方法 3.判断字符串是否带有小数点 二、实例 1.示例 2.生成成果 一、涉及到的相关知识 1.重载的方法 重载方法就是方法名称相同&#xff0c;但是每个方法中参数的数据类型、个数或顺序不同的方法。如果…

【开源】JAVA+Vue.js实现高校学院网站

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 学院院系模块2.2 竞赛报名模块2.3 教育教学模块2.4 招生就业模块2.5 实时信息模块 三、系统设计3.1 用例设计3.2 数据库设计3.2.1 学院院系表3.2.2 竞赛报名表3.2.3 教育教学表3.2.4 招生就业表3.2.5 实时信息表 四、系…

大语言模型不适合的范围

大语言模型在某些情况下可能不适用&#xff0c;主要体现在以下几个方面&#xff1a; 1、特定领域知识不足 大语言模型可能缺乏某些特定领域的专业知识&#xff0c;导致在特定行业或领域的问题上表现不佳。例如&#xff0c;在医学、法律等专业领域的术语和规范性语言理解方面可能…

收藏:《不要和不懂组织的人讨论管理》

刘润老师的文章&#xff1a;《不要和不懂组织的人讨论管理》&#xff0c;不错&#xff0c;收藏&#xff0c;地址&#xff1a;https://mp.weixin.qq.com/s?__bizMjM5NjM5MjQ4MQ&mid2651667396&idx1&snf98f294c19d1b6d6b608d013b4a39e32&chksmbd10608a8a67e99ce…

Vue-54、Vue技术vuex中四个map使用(mapState、mapGetters、mapActions、mapMutations)

1、mapState方法&#xff1a;用于帮助我们映射state中的数据为计算属性 computed:{//借助mapstate生成计算属性&#xff0c;从state中读取数据&#xff08;对象写法&#xff09;...mapState({sum:sum,school:school,subject:subject}),//借助mapstate生成计算属性&#xff0c;…

PyCharm2023.3.2配置conda环境

重点在于Path to conda这一步&#xff0c;需要找到conda.bat这个文件&#xff0c;PyCharm才能识别出现有的conda环境。

Spring Native 解放 JVM

一、Spring Native 是什么 Spring Native可以通过GraalVM将Spring应用程序编译成原生镜像&#xff0c;提供了一种新的方式来部署Spring应用。与Java虚拟机相比&#xff0c;原生镜像可以在许多场景下降低工作负载&#xff0c;包括微服务&#xff0c;函数式服务&#xff0c;非常…