zoukankan      html  css  js  c++  java
  • 性能测试必备知识(1)- 进程和线程的区别

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

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

    进程

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

    深挖进程

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

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

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

    什么是多进程

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

    线程

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

    深挖线程

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

    什么是多线程

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

    进程和线程的区别

     从几个层面去分析

    内存

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

    作用

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

    资源

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

    独立

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

    开销

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

    通信

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

    影响关系

    • 进程:进程崩溃之后,在系统保护模式下,不会对其他进程产生影响
    • 线程:一个线程崩溃之后,整个进程都会死掉
    • 总结:多进程比多线程要健壮
  • 相关阅读:
    Codeforces Round #604 (Div. 2) E. Beautiful Mirrors 题解 组合数学
    洛谷P1002 过河卒 题解 动态规划
    python 查看数据类型
    python 输出小技巧
    python 基础定义变量
    python 关键字
    flask restful 反查询
    Please edit configuration/connection/logging settings in '/home/mac126/Desktop/13/test3-1/migrations/alembic.ini' before proceeding.
    KeyError: 'migrate'错误解决办法
    flask 的简单拆分升级版2
  • 原文地址:https://www.cnblogs.com/poloyy/p/13301297.html
Copyright © 2011-2022 走看看