线程与进程的个人理解

devtools/2024/11/30 5:20:54/

进程(Process):

  1. 一个程序在执行时,操作系统为其分配的资源(如内存、CPU 时间等)构成了一个进程。
  2. 每个进程都有自己的独立的地址空间、堆栈和局部变量,它们之间不共享内存(除非通过特定的机制,比如共享内存或管道等)。
  3. 进程之间是隔离的,一个进程的崩溃通常不会影响到其他进程。

线程(Thread):

  1. 线程是进程中的执行单元,也叫做轻量级进程。一个进程至少有一个主线程(通常是程序启动时自动创建的),它也可以创建多个子线程来执行不同的任务。
  2. 线程之间共享同一个进程的地址空间和资源(如全局变量、打开的文件描述符等),但是每个线程都有自己的栈空间和程序计数器。
  3. 线程的创建和销毁比进程要轻量得多,因为它们共享父进程的资源,不需要独立的内存空间。

主线程(Main thread):

  1. 在程序启动时,操作系统会为程序创建一个主线程,也就是程序的入口点。
  2. 主线程通常负责启动程序的主要逻辑,在大多数程序中,主线程会处理用户输入、程序控制流等。

子线程(Child thread):

  1. 子线程是在程序运行过程中,由主线程或其他线程创建的线程。它们负责执行某些并行任务或辅助任务,以提高程序的效率。
    例如,主线程可能负责UI渲染,而子线程则负责后台计算或处理I/O操作。
  2. 子线程通常在执行完它们的任务后结束,可以通过线程的join()方法或其他同步机制来等待子线程结束,确保程序的正确性。

单核CPU:

  1. 单核CPU一次只能运行一个线程。尽管操作系统支持多线程,但它会使用时间片轮转的方式,在不同线程之间快速切换,让用户感觉到多个线程是同时执行的。实际上,这些线程是按顺序轮流执行的。

多核CPU:

  1. 多核CPU能够同时运行多个线程,每个核心可以运行一个线程。因此,在多核处理器上,如果程序能够有效地利用多个线程(比如多线程计算任务),就能实现更高的并行度和更好的性能。

线程的执行与独立性

  1. 每个线程都有自己的 程序计数器(Program Counter,PC),用于记录当前执行指令的地址,确保线程能按照正确的顺序执行。

  2. 每个线程都有自己的 寄存器 和 堆栈,它们存储的是与该线程执行相关的数据(如局部变量、函数调用信息等)。

  3. 不同的线程可以共享进程中的资源,例如全局变量、打开的文件、内存空间等。

  4. 然而,线程间的共享资源也带来了潜在的竞争问题。当多个线程同时访问同一资源时,如果不加以控制,可能会导致数据竞争(Race Condition)或不一致的状态。因此,线程间常常需要通过 同步机制(如互斥锁、信号量、条件变量等)来保证共享资源的正确访问。

多线程编程中的挑战

  1. 同步与互斥:多个线程访问共享数据时,需要进行同步操作,避免数据竞争和不一致。
  2. 死锁:如果多个线程互相等待对方释放资源,可能会导致程序永远无法继续执行。设计时要避免死锁的发生。
  3. 上下文切换:操作系统在多个线程间进行切换时,会保存和恢复线程的状态。频繁的上下文切换会带来性能损失,因此需要合理设计线程的使用。

如果主线程需要其他功能的辅助时,此时可以创建一个新的线程,这个线程是子线程,而函数里的原本的命令是主线程

也就是说我运行一个程序,系统自动会为其创建一个线程,此为父线程,而程序中创建的所有线程都是隶属于该父线程的子线程

一个代码整体就是一个任务,一个任务就是一个进程。

单核CPU一次只能运行一个线程,多核CPU可以运行多个。一个进程可以包括多个线程,每个线程运行时会有一个程序计数器,记录当前程序执行的位置,多个线程有多个程序计数器,每个线程独立运行。每个线程有自己的寄存器和堆栈,线程间共享地址空间、全局变量、打开的文件等等信息


http://www.ppmy.cn/devtools/138106.html

相关文章

设计模式学习之——观察者模式

观察者模式是一种行为型设计模式,它用于在对象之间建立一对多的依赖关系。 一、定义与角色 定义: 观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象。这个主题对象在状态发生变化时,会通知所有观察…

Linux 常用命令大全与详细讲解

Linux 作为一种流行的操作系统,广泛应用于服务器、开发环境和日常桌面使用中。Linux 的强大之处在于它的命令行工具,用户通过命令行可以执行系统管理、文件处理、网络配置等多种操作。本文将详细介绍一些 Linux 中最常用的命令,从文件操作到系…

深入讲解Spring Boot和Spring Cloud,外加图书管理系统实战!

很抱歉,我的疏忽,说了这么久还没有给大家详细讲解过Spring Boot和Spring Cloud,那今天给大家详细讲解一下。 大家可以和下面这三篇博客一起看: 1、Spring Boot 和 Spring Cloud 微服务开发实践详解https://blog.csdn.net/speaking_me/artic…

构建 LLM (大型语言模型)应用程序——从入门到精通(第七部分:开源 RAG)

通过检索增强生成 (RAG) 应用程序的视角学习大型语言模型 (LLM)。 本系列博文 简介数据准备句子转换器矢量数据库搜索与检索大语言模型开源 RAG(本帖)评估服务LLM高级 RAG 1. 简介 我们之前的博客文章广泛探讨了大型语言模型 (LLM),涵盖了其…

Jenkins-Git Parameter 插件实现指定版本的发布和回滚

在上一篇文章的基础设置上进行 1. 机器准备 开发10.0.0.204gitlab10.0.0.201jenkins10.0.0.200web10.0.0.202 2. 开发主机 在开发机器上修改不同版本的前端页面,并打上标签 第一次修改 [rootdev wheel]#vim index.html [rootdev wheel]#git commit -am "1…

c++设计模式模块与系统

c 中lambda 本质就是一个匿名(没有名)的函数; 可以用一个数组元素存储一个函数的指针; 通过数组下标来使用函数; 高内聚低耦合 如何理解设计模式中的高内聚低耦合 高内聚: 用于指导如何组织和划分软件设计。 **定义:**高内聚指的…

通信与网络安全之IPSEC

IPSec(IP Security)是IETF制定的为保证在Internet上传送数据的安全保密性能的三层隧道加密协议。IPSec在网络层对IP报文提供安全服务。IPSec协议本身定义了如何在IP数据包中增加字段来保证IP包的完整性、 私有性和真实性,以及如何加密数据包。…

微信小游戏/抖音小游戏SDK接入踩坑记录

文章目录 前言问题记录1、用是否存在 wx 这个 API 来判断是微小平台还是抖小平台不生效2、微小支付的参数如何获取?3、iOS 平台不支持虚拟支付怎么办?微小 iOS 端支付时序图:抖小 iOS 端支付:4、展示广告时多次回调 onClose5、在使用单例时 this 引起的 bug6、使用 fetch 或…