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

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

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

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

 

进程


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

image.png


深挖进程

image.png

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

 

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

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

 

什么是多进程

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

 

线程


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

 

深挖线程

image.png

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

 

什么是多线程

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

 

进程和线程的区别


从几个层面去分析

内存

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

 

作用

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

 

资源

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

 

独立

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

 

开销

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

 

通信

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

 

影响关系

  • 进程:进程崩溃之后,在系统保护模式下,不会对其他进程产生影响
  • 线程:一个线程崩溃之后,整个进程都会死掉
  • 总结:多进程比多线程要健壮
相关实践学习
通过性能测试PTS对云服务器ECS进行规格选择与性能压测
本文为您介绍如何利用性能测试PTS对云服务器ECS进行规格选择与性能压测。
相关文章
|
17天前
|
安全 Java 数据处理
Python网络编程基础(Socket编程)多线程/多进程服务器编程
【4月更文挑战第11天】在网络编程中,随着客户端数量的增加,服务器的处理能力成为了一个重要的考量因素。为了处理多个客户端的并发请求,我们通常需要采用多线程或多进程的方式。在本章中,我们将探讨多线程/多进程服务器编程的概念,并通过一个多线程服务器的示例来演示其实现。
|
1月前
|
消息中间件 安全 Linux
线程同步与IPC:单进程多线程环境下的选择与权衡
线程同步与IPC:单进程多线程环境下的选择与权衡
64 0
|
1月前
|
消息中间件 存储 算法
【软件设计师备考 专题 】操作系统的内核(中断控制)、进程、线程概念
【软件设计师备考 专题 】操作系统的内核(中断控制)、进程、线程概念
83 0
|
1月前
|
安全 Python
Python中的并发编程:多线程与多进程技术探究
本文将深入探讨Python中的并发编程技术,重点介绍多线程和多进程两种并发处理方式的原理、应用场景及优缺点,并结合实例分析如何在Python中实现并发编程,以提高程序的性能和效率。
|
1月前
|
消息中间件 Linux 调度
【Linux 进程/线程状态 】深入理解Linux C++中的进程/线程状态:阻塞,休眠,僵死
【Linux 进程/线程状态 】深入理解Linux C++中的进程/线程状态:阻塞,休眠,僵死
70 0
|
1天前
|
安全 Java
【JAVA】线程的run()和start()有什么区别?
【JAVA】线程的run()和start()有什么区别?
|
4天前
|
Java 数据库连接 数据处理
Python从入门到精通:3.1.2多线程与多进程编程
Python从入门到精通:3.1.2多线程与多进程编程
|
11天前
|
调度 Python
Python多线程、多进程与协程面试题解析
【4月更文挑战第14天】Python并发编程涉及多线程、多进程和协程。面试中,对这些概念的理解和应用是评估候选人的重要标准。本文介绍了它们的基础知识、常见问题和应对策略。多线程在同一进程中并发执行,多进程通过进程间通信实现并发,协程则使用`asyncio`进行轻量级线程控制。面试常遇到的问题包括并发并行混淆、GIL影响多线程性能、进程间通信不当和协程异步IO理解不清。要掌握并发模型,需明确其适用场景,理解GIL、进程间通信和协程调度机制。
28 0
|
26天前
|
安全 Linux API
Android进程与线程
Android进程与线程
19 0
|
1月前
|
存储 算法 Linux
【Linux 系统标准 进程资源】Linux 创建一个最基本的进程所需的资源分析,以及线程资源与之的差异
【Linux 系统标准 进程资源】Linux 创建一个最基本的进程所需的资源分析,以及线程资源与之的差异
26 0

热门文章

最新文章