专栏首页自动化、性能测试性能测试必备知识(1)- 进程和线程的区别

性能测试必备知识(1)- 进程和线程的区别

做性能测试的必备知识系列,可以看下面链接的文章哦

https://www.cnblogs.com/poloyy/category/1806772.html

进程

  • 一个正在运行的应用程序
  • 比如,在 Window下,一个运行中的 exe 就是一个进程(如下图)

深挖进程

  • 一个进程可以有很多个线程,但至少有一个线程
  • 内存是逻辑内存
  • 文件/网络句柄就是资源文件

进程有多个线程的场景类比

  • 打开一个 qq,就是一个进程
  • 很多个聊天框,就是很多个线程在同时运行中

什么是多进程

  • 同时运行多个应用程序
  • 当你打开电脑,就已经是多进程模式了,同时跑着多个不同的程序

线程

进程中的一个任务调度和执行的基本单位

深挖线程

  • PC:program contact,存放的是当前下一条执行指令的地址
  • TLS:安全传输层协议
  • PC 指向内存:相当于操作系统运行的是一个个线程,进程只是容器,指令本身放在内存;同一进程中的线程共享相同的地址空间,因此可以读写同样的数据结构和变量,便于通信

什么是多线程

  • 在同一个进程中同时运行多个任务
  • 比如:在 qq 和多个人、群同时聊天

进程和线程的区别

从几个层面去分析

内存

  • 进程:不共享内存
  • 线程:共享进程的内存空间

作用

  • 进程:是 CPU 资源分配的最小单位,它主要用来就是资源的分配
  • 线程:是 CPU 调度执行的最小单位,它主要用来系统调度

资源

进程共享系统的文件、网络资源,而线程会共享进程的资源文件

独立

  • 进程:独立存在,有自己的内存地址
  • 线程:不可以独立,必须依赖进程而存在

开销

  • 进程:需要分配内存,开销较大
  • 线程:只需要分配栈和一个 PC,开销比较小

通信

  • 进程:进程间通信比较复杂,因为它的数据空间独立性,需要通过操作系统,基于 socket 的进程间的通信机制
  • 线程:线程间的通信由于多线程共享内存地址空间和数据空间,可直接通信,不必通过操作系统(内核的调度),比较简单

影响关系

  • 进程:进程崩溃之后,在系统保护模式下,不会对其他进程产生影响
  • 线程:一个线程崩溃之后,整个进程都会死掉
  • 总结:多进程比多线程要健壮

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 性能测试必备知识(10)- Linux 是怎么管理内存的?

    https://www.cnblogs.com/poloyy/category/1806772.html

    小菠萝测试笔记
  • 软件评测师笔记(五)—— 计算题

    DABFFH-B3000H+1=27C00H = 10 0111 1100 0000 0000 = 10 0111 11K = 159K

    小菠萝测试笔记
  • Jmeter系列(54)- 详解 Runtime Controller 运行周期控制器

    一种设置运行时间的控制器,它的效果就是使该控制器下的子项运行时间为【Runtime】中的数值(单位:s)

    小菠萝测试笔记
  • 轻松实现Python中的多进程与多线程

    在开始讲今天的正文之前,先给大家介绍一个概念「多线程工作」,这个概念可能有的人听过,也可能有的人平常工作中就是这么做的。我再来给大家讲讲这个概念,所谓的「多线程...

    1480
  • 你能分清多进程与多线程吗?

    在开始讲今天的正文之前,先给大家介绍一个概念「多线程工作」,这个概念可能有的人听过,也可能有的人平常工作中就是这么做的。我再来给大家讲讲这个概念,所谓的「多线程...

    张俊红
  • 多线程三分钟就可以入个门了!

    Java3y
  • python中的进程与线程基本使用(上)

    本系列课程是针对无基础的,争取用简单明了的语言来讲解,学习前需要具备基本的电脑操作能力,准备一个已安装python环境的电脑。如果觉得好可以分享转发,有问题的地...

    用户7054460
  • 阿里历年经典Java面试题汇总

    当写一个volatile变量时,JMM会把线程对应的本地内存中的共享变量值刷新到主内存。

    Java团长
  • 阿里历年经典Java面试题汇总

    三哥
  • 装饰器模式

    用户2434869

扫码关注云+社区

领取腾讯云代金券