进程与线程 落日映苍穹つ 2021-09-26 13:08 383阅读 0赞 进程与线程: ***基本概念***: **进程**:进程是正在运行的程序的实例。每个进程都有自己的地址空间,一般情况下,它包括文本区域、数据区域和堆栈。文本区域存储处理器执行的代码;数据区域存储变量和进程执行期间使用的动态分配的内存,堆栈区存储着活动过程调用的指令和本地变量。进程由程序、数据和进程控制块组成。 **线程**:线程是进程中的一个实体,CPU调度的基本单位。线程不再拥有系统资源,只拥有一点在运行中必不可少的资源,但它可以与同一进程的其它线程共享进程所拥有的全部资源。(线程有时也被称为轻量级进程,它是程序执行的最小单元。) ***区别***: 1. 进程是资源分配的最小单位;线程是CPU调度的基本单位。 2. 一个进程至少有一个线程;它们共享进程的地址空间,而进程有自己独立的地址空间。 3. 进程间的通信方式包括管道、消息队列、信号量、套接字(Socket)、共享存储。线程间的通信方式包括共享变量和队列。 ***联系***: 1. 二者均可并发执行。 2. 它们都有三种状态:运行态、就绪态和阻塞态。 (示例代码待完善~) **进程间通信**(原文链接:[https://www.cnblogs.com/efforts-will-be-lucky/p/7199980.html][https_www.cnblogs.com_efforts-will-be-lucky_p_7199980.html]): (1) 管道:通常指的是无名管道,是UNIX系统IPC最古来的形式。 (2) 消息队列:是消息的链接表,存放在内核中。一个消息队列由一个标识符来标识。 (3) 信号量:它是一个计数器,用于实现进程间的互斥与同步,而不是用于存储进程间通信的数据。 (4) 共享内存:指的是两个或多个进程共享一个给定的存储区。 (5) 套接字(Socket):套解口也是一种进程间通信机制,与其他通信机制不同的是,它可用于不同机器间的进程通信。 **线程间通信**(原文链接:[https://www.cnblogs.com/efforts-will-be-lucky/p/7199980.html][https_www.cnblogs.com_efforts-will-be-lucky_p_7199980.html]): 1. 共享变量 实现方式:wait(),notify(),以及notifyAll() (1) wait()方法使得当前线程必须要等待,等到另外一个线程调用notify()或者notifyAll()方法。 (2) notify()方法会唤醒一个等待当前对象的锁的线程。而notifyAll()顾名思义;就是唤醒所有在等待中的方法; (3) wait()和notify()方法要求在调用时线程已经获得了对象的锁,因此对这两个方法的调用需要放在synchronized方法或synchronized块中。 2. 队列 实现方式:这里用的是java.util.concurrent包中linkedBlockingQueue 来进行线程间交互; (1) java.util.concurrent.LinkedBlockingQueue 是一个基于单向链表的、范围任意的(其实是有界的)、FIFO 阻塞队列。访问与移除操作是在队头进行,添加操作是在队尾进行,并分别使用不同的锁进行保护,只有在可能涉及多个节点的操作才同时对两个锁进行加锁。 [https_www.cnblogs.com_efforts-will-be-lucky_p_7199980.html]: https://www.cnblogs.com/efforts-will-be-lucky/p/7199980.html
相关 进程与线程 有那么一些零碎的小知识点,偶尔很迷惑,偶尔被忽略,偶然却发现它们很重要,也是各大笔试和面试高频出现考点。这段时间正好在温习这些,就整理在这里,一起学习一起提高!后面还会继续补充 痛定思痛。/ 2022年05月30日 00:19/ 0 赞/ 267 阅读
相关 线程与进程 1.定义 进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位. 线程是进程的一个实体,是CPU调度和分派的基本 - 日理万妓/ 2022年05月23日 01:56/ 0 赞/ 118 阅读
相关 进程与线程 [进程与线程][Link 1] 推荐一篇讲解的非常透彻且非常形象的文章,阮一峰的一篇博文。 原文链接:[进程与线程的一个简单解释][Link 2] posted @ 秒速五厘米/ 2022年03月22日 11:09/ 0 赞/ 257 阅读
相关 线程与进程 进程 1. 进程是资源分配的最小单位。 2. 开销: 有独立的代码和数据空间,程序切换开销大。 3. 坏境: 能同时运行多个进程(程序)。 4. 内存: 系统在运 骑猪看日落/ 2022年03月17日 10:14/ 0 赞/ 232 阅读
相关 进程与线程 进程,是一个活动的实体,我们平时所说的程序或者可执行文件并不是一个进程,他们都属于被动实体,只有将程序或者可执行文件调入到内存中才能成为一个活动实体,才能称之为进程。 进程是 小鱼儿/ 2022年01月16日 04:27/ 0 赞/ 273 阅读
相关 进程与线程 进程的定义 由于程序在并发执行时,各次执行的结果不同,所以用“程序”这个概念已无法描述程序的并发执行,所以必须引入新的概念 – 进程来描述程序的并发执行。 根据1978 比眉伴天荒/ 2022年01月15日 01:05/ 0 赞/ 287 阅读
相关 进程与线程 进程至少包含三个组成要素:程序快、代码块以及进程控制块; 进程是系统中资源分配和保护的基本单位; 线程作为CPU的调度和分派的基本单位; 每个进程在创建的时候,至少 Dear 丶/ 2022年01月11日 07:49/ 0 赞/ 311 阅读
相关 进程与线程 一般可以把独立运行的程序看作一个进程,进程之间是相互独立存在的,像qq音乐,谷歌浏览器一样他们都是独立存在的,而且互不影响。 进程想要执行任务必须依赖于线程,进程中的最小执行 ﹏ヽ暗。殇╰゛Y/ 2021年12月03日 10:49/ 0 赞/ 238 阅读
相关 进程与线程 进程与线程: 基本概念: 进程:进程是正在运行的程序的实例。每个进程都有自己的地址空间,一般情况下,它包括文本区域、数据区域和堆栈。文本区域存储处理器执行的代码;数据区 落日映苍穹つ/ 2021年09月26日 13:08/ 0 赞/ 384 阅读
相关 进程与线程 进程与线程 1 进程 1.1 进程的概念 进程就是正在运行的程序,它代表了程序所占用的内存区域 1.2 进程的特点 独立性 进程是系 忘是亡心i/ 2021年09月07日 06:19/ 0 赞/ 585 阅读
还没有评论,来说两句吧...