进程和线程的区别和联系

简介: 进程和线程的区别和联系

前言

(18条消息) 进程调度的基本过程_Y君的进化史的博客-CSDN博客一文中,我们初步了解了关于进程的知识,本文重点讲解进程和线程的区别和联系。

一个线程就是一个“执行流”。


目录

前言

一、组织方式

二、包含关系

三、区别(面试常考)

结语


一、组织方式

在前文中,我们学习了PCB这个进程控制块,操作系统使用双向链表来组织PCB。

PCB中包含一些属性,使得PCB在底层是用一个结构体实现的。
在Windows系统上,描述进程和线程是用不同的结构体,也就是进程是使用PCB,但是线程不是。

在Linux系统上,进程和线程都是使用PCB这个结构体。

二、包含关系

一个进程在创建时,会自动生成一个线程,也就是说,每个进程至少包含一个线程,即主线程


同时,一个PCB对应一个线程,也就是多个PCB对应一个进程。

在同一个进程的多个PCB里,内存指针(虚拟地址空间(内存资源))、文件描述符表(硬盘资源)都是相同的。

不同线程,也就是不同PCB中,上下文、状态、优先级、记账信息等都是不同的。

三、区别(面试常考)

1.进程包含线程。每个进程至少有一个线程存在,即主线程。

2.都是实现并发编程的方式,但线程比进程更轻量。创建线程比创建进程更快,销毁线程比销毁进程更快,调度线程比调度进程更快。
3.操作系统创建进程,要给进程分配资源,进程是系统分配资源的基本单位。操作系统创建线程,是要在CPU上调度执行,线程是系统调度执行的基本单位

4.进程具有独立性,每个进程都有自己的虚拟空间,彼此之间不会相互影响,进程的独立性导致系统的稳定性上升。同一个进程的线程之间共用一份地址空间,一个线程出现异常,会导致整个进程异常结束,多个线程之间容易相互影响


结语

这篇博客如果对你有帮助,给博主一个免费的点赞以示鼓励,欢迎各位🔎点赞👍评论收藏⭐,谢谢!!!

相关文章
|
5天前
|
存储 消息中间件 资源调度
「offer来了」进程线程有啥关系?10个知识点带你巩固操作系统基础知识
该文章总结了操作系统基础知识中的十个关键知识点,涵盖了进程与线程的概念及区别、进程间通信方式、线程同步机制、死锁现象及其预防方法、进程状态等内容,并通过具体实例帮助理解这些概念。
「offer来了」进程线程有啥关系?10个知识点带你巩固操作系统基础知识
|
4天前
|
资源调度 算法 调度
深入浅出操作系统之进程与线程管理
【9月更文挑战第29天】在数字世界的庞大舞台上,操作系统扮演着不可或缺的角色,它如同一位精通多门艺术的导演,精心指挥着每一个进程和线程的演出。本文将通过浅显的语言,带你走进操作系统的内心世界,探索进程和线程的管理奥秘,让你对这位幕后英雄有更深的了解。
|
8天前
|
Java
直接拿来用:进程&进程池&线程&线程池
直接拿来用:进程&进程池&线程&线程池
|
9天前
|
负载均衡 Java 调度
探索Python的并发编程:线程与进程的比较与应用
本文旨在深入探讨Python中的并发编程,重点比较线程与进程的异同、适用场景及实现方法。通过分析GIL对线程并发的影响,以及进程间通信的成本,我们将揭示何时选择线程或进程更为合理。同时,文章将提供实用的代码示例,帮助读者更好地理解并运用这些概念,以提升多任务处理的效率和性能。
|
19天前
|
开发者 Python
深入浅出操作系统:进程与线程的奥秘
【8月更文挑战第46天】在数字世界的幕后,操作系统扮演着至关重要的角色。本文将揭开进程与线程这两个核心概念的神秘面纱,通过生动的比喻和实际代码示例,带领读者理解它们的定义、区别以及如何在编程中运用这些知识来优化软件的性能。无论你是初学者还是有一定经验的开发者,这篇文章都将为你提供新的视角和实用技巧。
|
3天前
|
NoSQL 网络协议 Unix
1)Redis 属于单线程还是多线程?不同版本之间有什么区别?
1)Redis 属于单线程还是多线程?不同版本之间有什么区别?
8 0
|
3天前
|
数据采集 消息中间件 并行计算
进程、线程与协程:并发执行的三种重要概念与应用
进程、线程与协程:并发执行的三种重要概念与应用
11 0
|
3天前
|
数据采集 Linux 调度
Python之多线程与多进程
Python之多线程与多进程
10 0
|
8天前
|
存储 算法 Java
关于python3的一些理解(装饰器、垃圾回收、进程线程协程、全局解释器锁等)
该文章深入探讨了Python3中的多个重要概念,包括装饰器的工作原理、垃圾回收机制、进程与线程的区别及全局解释器锁(GIL)的影响等,并提供了详细的解释与示例代码。
15 0
|
11天前
|
并行计算 API 调度
探索Python中的并发编程:线程与进程的对比分析
【9月更文挑战第21天】本文深入探讨了Python中并发编程的核心概念,通过直观的代码示例和清晰的逻辑推理,引导读者理解线程与进程在解决并发问题时的不同应用场景。我们将从基础理论出发,逐步过渡到实际案例分析,旨在揭示Python并发模型的内在机制,并比较它们在执行效率、资源占用和适用场景方面的差异。文章不仅适合初学者构建并发编程的基础认识,同时也为有经验的开发者提供深度思考的视角。