计算机中信息的表示和处理 整数和小数的二进制表示

news2024/9/24 17:20:39

信息的表示和处理

  • 整数
    • 进制
    • 移位运算
    • 无符号数和有符号数
    • 加法运算
  • 小数
    • 定点表示
    • IEEE 浮点表示
      • 规格化和非规格化
      • 舍入
      • 浮点运算

  • 现代计算机存储和处理的信息以二值信号表示,这些二进制数字称为位,为什么要用二进制来进行编码?因为二进制只有1和0两种状态,正好可以用高低电平来表示,同时可以数值之间可以方便的进行逻辑和算数运算,否则如果用人类容易理解的十进制编码,那机器如何识别这10个状态呢?比较困难
  • 大多数计算机用8位的块(比特),或者说1字节作为最小的可寻址的内存单位,而不是访问内存中单独的位。机器级程序将内存视为一个非常大的字节数组,称为虚拟内存(virtual memory),内存中每一个字节都有一个唯一数字标识,称为它的地址(address)

整数

进制

  • 二进制 ( B i n a r y ) (Binary) (Binary)后缀是 B B B,十进制 ( D e c i m a l ) (Decimal) (Decimal)后缀是 D D D,八进制 ( O c t a l ) (Octal) (Octal)后缀是 O O O,十六进制 ( H e x ) (Hex) (Hex)后缀是 H H H
  • 这里相信读者对任意进制转十进制以及十进制转任意进制(整数和小数部分分开处理然后拼起来)并不陌生,简单说一下二进制和八进制或者十六进制的互相转化,比如下面这个十六进制数
    0 x 39 A 7 F 8 0x39A7F8 0x39A7F8
  • 怎么把它转化成二进制数?最简单的办法就是一位一位转换,比如 3 3 3可以转换成 ( 0011 ) 2 (0011)_2 (0011)2 9 9 9可以转化成 1001 1001 1001这样转化下去,拼起来就可以得到结果如下
    0011   1001   1010   0111   1111   1000 0011\ 1001\ 1010\ 0111\ 1111\ 1000 0011 1001 1010 0111 1111 1000
  • 二进制转十六进制一个道理

  • 在Windows系统中我们也许知道有32位和64位的区别,那么这个区别到底是什么呢?事实上,每台计算机都有一个字长(word size),指明指针数据的标称大小(nominal size),字长决定的最重要的系统参数就是虚拟地址空间的访问最大大小,也就是说,对于一个字长为 w w w的机器而言,虚拟地址的范围就是 0 − 2 w − 1 0-2^w-1 02w1,程序最多访问 2 w 2^w 2w个字节,那么32位系统的虚拟地址空间就是 2 3 2 2^32 232个字节,大概是4GB
  • 那么问题来了,跨越多字节的程序对象如何处理呢?答案应该是使用地址来找到这个对象,同时还要知道如何在内存中排列这些字节。因为几乎所有的机器上多字节对象都被存储位连续的字节序列,对象的地址为所使用字节中最小的地址
  • 有两种方法排列这些字节,要么从低到高,称为小端法(little endian),要么从高到低,称为大端法(big endian),这里的高低可以这样理解,比如数字123456,1属于高,6属于低。有时候这会造成问题,比如网络传输数据的时候,不同方法的机器可能导致传输字节反序,这需要注意,我们可以看下面这个例子
#include <bits/stdc++.h>

using namespace std;

typedef unsigned char *byte_pointer;

void show_bytes(byte_pointer start, size_t len){
  size_t i;// unsigned int
  for(int i=0;i<len;i++){
    printf(" %.2x", start[i]);// start是val的首地址,因为两个十六进制位占1个字节,所以输出两位
  }
  printf("\n");
}
int main(){
  int val = 0x87654321;
  byte_pointer valp = (byte_pointer) &val;// 取地址
  show_bytes(valp, 1);// 21
  show_bytes(valp, 2);// 21 43
  show_bytes(valp, 3);// 21 43 65
  return 0;
}
  • 可以测试一下运行结果,小端法机器输出如上图
  • 我们可以用C语言的运算符sizeof来确定对象使用的字节数

移位运算

  • 默认读者使用过移位运算,大概知道怎么回事,C语言移位有左移和右移,左移就是末位补0,高位舍弃;右移有两种,算数右移和逻辑右移,但C语言没有明确规定,逻辑右移是在左端补0,算数右移是在左端补最高位的值,比如现在最高位是1,那就在左端全补1,也就是说算数右移不改变数的正负
  • 而Java中规定明确,x>>k表示算数右移,x>>>k表示逻辑右移

无符号数和有符号数

  • 假设一个整数数据类型有 w w w位,我们可以把位向量写成 x ⃗ \vec{x} x ,表示整个向量,那么整个数字就是 [ x w − 1 , x w − 2 , ⋯   , x 0 ] [x_{w-1},x_{w-2},\cdots,x_{0}] [xw1,xw2,,x0],表示向量中的每一位,所以对于一个无符号数有 B 2 U w ( x ⃗ ) = ∑ i = 0 w − 1 x i 2 i B2U_{w}(\vec{x})=\sum_{i=0}^{w-1}x_i2^i B2Uw(x )=i=0w1xi2i其中 B 2 U w B2U_{w} B2Uw表示 B i n a r y   t o   U n s i g n e d Binary\ to\ Unsigned Binary to Unsigned,长度为 w w w,这个函数是一个双射,意思就是正向一对一,反向也一对一,所以我们可以用每一个数表示一个状态,进行状态压缩
  • 对于有符号数,一般计算机表示方式是补码形式,我们用函数 B 2 T w ( B i n a r y   t o   T w o ′ s − c o m p l e m e n t ) B2T_w(Binary\ to\ Two's-complement) B2Tw(Binary to Twoscomplement)表示,补码编码的定义如下,对向量 x ⃗ = [ x w − 1 , x w − 2 , ⋯   , x 0 \vec{x}=[x_{w-1},x_{w-2},\cdots,x_0 x =[xw1,xw2,,x0],有 B 2 T w ( x ⃗ ) = − x w − 1 2 w − 1 + ∑ i = 0 w − 2 x i 2 i B2T_w(\vec{x})=-x_{w-1}2^{w-1}+\sum_{i=0}^{w-2}x_i2^i B2Tw(x )=xw12w1+i=0w2xi2i
  • 有符号数的另外两种标准的表示方法是原码反码,原码 ( S i g n − M a g n i t u d e ) (Sign-Magnitude) (SignMagnitude)的最高有效位是符号位,用来确定剩下的位是正权还是负权,有 B 2 S w ( x ⃗ ) = ( − 1 ) x w − 1 × ( ∑ i = 0 w − 2 x i 2 i ) B2S_w(\vec{x})=(-1)^{x_{w-1}}\times (\sum_{i=0}^{w-2}x_i2^i) B2Sw(x )=(1)xw1×(i=0w2xi2i)
  • 反码 ( O n e ′ s   C o m p l e m e n t ) (One's\ Complement) (Ones Complement)表示的话,最高有效位的权比补码多了个1,表示如下 B 2 O w ( x ⃗ ) = − x w − 1 ( 2 w − 1 − 1 ) + ∑ i = 0 w − 2 x i 2 i B2O_w(\vec{x})=-x_{w-1}(2^{w-1}-1)+\sum_{i=0}^{w-2}x_i2^i B2Ow(x )=xw1(2w11)+i=0w2xi2i
  • 但是你会发现原码和反码在表示0的时候都有两种情况,原码是因为最高位表示符号,是不是1对于0无影响,反码是因为最高有效位权多了个1,导致所有位都是1的时候值变成了0
  • 对于很多国内教材,讲到补码的时候会说,对于一个正整数,补码和原码相同(原码就是这个数转化成二进制),对负整数来说,补码是原码取反+1,从上面的公式中可以轻松推出这一结论
  • C语言中的强制类型转换非常简单,就是位表示不会改变,只是改变了解释这些位的方式,那么如果一个有符号的负数转化成一个无符号的数就可能变成一个大正数,如果位不够要进行扩展,扩展可能是零扩展也可能是符号扩展,这个和逻辑右移与算数右移比较类似,如果位太多要截断,这里书中有详细介绍,我就不求甚解了

加法运算

  • 显然由于计算机字长和内存的限制,一个数字不能无限制的增大,否则就会失去它原本的意义,加法实际上就是超过部分舍掉就完事了,两个无符号数加法公式如下 x + w u y = { x + y , x + y < 2 w 正常 x + y − 2 w , 2 w ≤ x + y < 2 w + 1 溢出 x+{^u_w}y=\begin{cases}x+y,\quad &x+y\lt 2^w &正常 \\ x+y-2^w,&2^w\leq x+y\lt2^{w+1} &溢出 \end{cases} x+wuy={x+y,x+y2w,x+y<2w2wx+y<2w+1正常溢出
  • 补码加法同理 x + w t y = { x + y − 2 w , 2 w − 1 ≤ x + y 正溢出 x + y , − 2 w − 1 ≤ x + y < 2 w − 1 正常 x + y + 2 w , x + y < − 2 w − 1 负溢出 x+{^t_w}y=\begin{cases}x+y-2^w,\quad &2^{w-1}\leq x+y &正溢出 \\ x+y,&-2^{w-1}\leq x+y\lt2^{w-1} &正常\\x+y+2^w,&x+y\lt -2^{w-1} &负溢出\end{cases} x+wty= x+y2w,x+y,x+y+2w,2w1x+y2w1x+y<2w1x+y<2w1正溢出正常负溢出
  • 上面的公式简单来说就是,你就直接加,超出位数就不要了,得到的答案就是运算结果

小数

定点表示

  • 小数转化为二进制比较容易,对于整数部分,按照整数转化为二进制的方式进行转化;对于小数部分,通常采用的方法是乘 2 2 2取整,直到符合的位数
  • 这是定点表示的方法,但是对于类似 1 × 2 100 1\times2^{100} 1×2100这样非常巨大的数字,我们不能够使用定点表示的方法,接下来看如何使用浮点表示

IEEE 浮点表示

  • 浮点数对形如 V = x × 2 y V=x\times 2^y V=x×2y的有理数进行编码,换句话说就是将小数转换为二进制表示,然后再对其进行编码,乘 2 y 2^y 2y是什么意思?就是二进制移位

IEEE浮点标准用 V = ( − 1 ) s × M × 2 E V=(-1)^s\times M\times 2^E V=(1)s×M×2E的形式来表示一个数

  • 符号(sign)s决定这个数是正数还是负数,而对于数值0的符号位解释作为特殊情况处理
  • 尾数(significand)M是一个二进制小数,它的范围是 1 ∼ 2 − ε 1\sim2-\varepsilon 12ε,或者是 0 ∼ 1 − ε 0\sim1-\varepsilon 01ε
  • 阶码(exponent)E的作用是对浮点数加权,这个权重是2的E次幂(可能是负数)

将浮点数的位表示划分为三个字段,分别对这些值进行编码,分为单精度(32位的float)和双精度(64位的double)
在这里插入图片描述

  • 根据上图可以解决一个问题,那就是单精度和双精度数能精确到小数点后多少位,根据即将要讲到的规格化定义,尾数表示的是 2 M + 1 2^{M+1} 2M+1,所以显然单精度能表示到 2 24 = 16777216 2^{24}=16777216 224=16777216,这个数在 1 0 7 10^7 107 1 0 8 10^8 108之间,排除掉最后一位的舍入问题,单精度能精确到小数点后 6 6 6位;同理双精度能表示到 2 53 = 9007199254740992 2^{53}=9007199254740992 253=9007199254740992,在 1 0 16 10^{16} 1016 1 0 17 10^{17} 1017之间,所以能精确到小数点后 15 15 15

规格化和非规格化

在这里插入图片描述
下面对上图进行一些解释

  • 根据阶码,引入了规格化和非规格化的概念,如果阶码的所有二进制位不全为0,也不全为1,那么就说这个二进制小数是规格化的,但是在这种情况下,阶码字段被解释成以偏置(biased)形式表示的有符号整数,也就是说,阶码的值是 E = e − B i a s E=e-Bias E=eBias,其中 e e e是无符号数,而 B i a s Bias Bias是一个等于 2 k − 1 − 1 2^{k-1}-1 2k11(单精度127,双精度1023)的偏置值。由此,指数的取值范围对于单精度是 − 126 ∼ + 127 -126\sim+127 126+127,双精度是 − 1022 ∼ + 1023 -1022\sim+1023 1022+1023,小数字段 f r a c frac frac被解释为描述小数值 f f f,这个 f f f的范围是 [ 0 , 1 ) [0,1) [0,1),二进制表示为 0. f n − 1 . . . f 1 f 0 0.f_{n-1}...f_1f_0 0.fn1...f1f0,正常情况下是这样,但是我们可以通过调整阶码 E E E让这个二进制数变成 1. f n − 1 f n − 2 . . . f 0 1.f_{n-1}f_{n-2}...f_0 1.fn1fn2...f0,这样,这个开头的 1 1 1不需要记录,就提高了1位的精度位,这就是规格化表示
  • 对于非规格化,阶码域就全是0,阶码值是 E = 1 − B i a s E=1-Bias E=1Bias,这样设置阶码值的意义是从规格化到非规格化能够平滑转换,而尾数的值是 M = f M=f M=f,也就是小数字段的值,不包括隐含的开头的1,因为规格化数后面的二进制小数是1.几,所以没办法表示0,那么非规格化就可以表示 0.0 0.0 0.0,但是如果符号位是1的话,得到的就是 − 0.0 -0.0 0.0,IEEE浮点格式对这两种数也有它自己的规定,另外一个就是逐渐下溢,可以表示非常接近于0.0的数
  • 当阶码所有位都是1的时候,如果小数域都是0,那么这个数就表示无穷,不都是0就表示NaN(Not a Number),如果有两个非常大的数相乘,那么得到的结果就会是inf,也就是无穷

舍入

  • 因为浮点数只能近似表示实数,所以需要考虑如何进行舍入,一般有四种舍入方式,下面以舍入到整数为例
  1. 向上舍入,很简单,比如1.2,向上舍入就是2,如果是-1.2向上舍入就是-1,就是往大了取
  2. 向下舍入,和第一个相反,1.2向下舍入是1,-1.2向下舍入是-2
  3. 向零舍入,1.2向零舍入就是1,-1.2向零舍入就是-1
  4. 向偶数舍入,这个比较特殊,它将数字向上或者向下舍入,使得最终结果是距离这个数字最近的数;如果距离相等则舍入到有效数字的最后一位是一个偶数的数,比如说1.4会舍入到1,因为1.4处于1和2之间,而它距离1比较近,所以舍入到1;如果是1.5,因为它距离1和2一样近,这个时候因为1是个奇数,所以需要舍入到2,如果是2.5则向下舍入到2。那么为什么要引入这样奇怪的方式呢?主要是避免大量的向上或者向下取整带来的统计偏差,相当于取了一个平均值

浮点运算

  1. 对阶,目的是让两个操作数的小数点位置对齐,使得两个数的阶码相等,这样我们先求阶差,然后以小阶向大阶对齐的原则,具体操作过程就是尾数右移,给阶码腾出空间,这样尾数的低位数就会丢失,这也就说明了为什么要以小阶向大阶对齐,如果返回来那么势必要左移,这样尾数的高位就要丢失,产生错误,因为低位丢失误差较小,高位丢失误差很大
  2. 尾数求和,将对阶之后的尾数按照定点数加(减)运算规则运算。运算后的尾数不一定是规格化的,因此,浮点数的加减运算需要进一步进行规格化处理
  3. 规格化,IEEE 754规格化尾数的形式是 ± 1. \pm1. ±1.x ⋯ \cdots x,但是尾数加减之后不一定能得到这种情况,可能小数点之前好几位,或者小数点前面是0,这时候需要进行规格化处理,具体方法是左规右规,直到最高位1移动到小数点前作为隐藏位,这个在前面的规格化中已经说过
  4. 舍入,因为前面对尾数进行了一些右移操作,可能会造成一些浮点误差,为了保证运算精度,一般将低位移出的两位保留下来,参加中间过程的运算,最后将运算结果进行舍入,还原表示成IEEE 754格式,常见的舍入方法有0舍1入法(舍去的尾数最高位如果是1则对新的尾数+1,否则不动,但是这样可能使尾数溢出,此时需要再做一次右规)、恒置1法(只要因移位而丢失的位中有1就把尾数末位置1)和截断法(恒舍法)(直接截取所需位数,丢弃后面的所有位)
  5. 溢出判断,看指数是不是超过了最大允许值或者低于最小允许值,如果是这样的话就发生了溢出,进行相应的处理

阿贝尔群:又称交换群或加群,它由自身的集合G和二元运算*组成,它除了满足一般的群公理,即运算的结合律、G有单位元、所有G的元素都有逆元之外,还满足交换律公理。因为阿贝尔群的群运算满足交换律和结合律,群元素乘积的值与乘法运算时的次序无关,换句话说对于任意的 a , b ∈ G a,b\in G a,bG,都有 a b = b a ab=ba ab=ba,或者说 a + b = b + a a+b=b+a a+b=b+a

  • 可以看出整数加法形成了一个阿贝尔群,而浮点数加法由于可能溢出到无穷大并不满足结合律所以不是一个阿贝尔群,这个需要注意

未完待续

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/400176.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

信捷 XDH Ethercat A_STOP指令

本指令使运动中的轴进行减速停止/急停。最常见的情况是用来停止以指定速度运行的轴。只要在运动&#xff0c;都可以用本指令停止。上图中&#xff0c;在M150的上升沿&#xff0c;执行A_STOP指令。A_STOP HD150 D150 M151 K0HD150--输入参数起始地址&#xff0c;HD158--输入参数…

创宇猎幽APT流量监测系统获CSTC年度网络安全优秀案例

近日&#xff0c;由中国软件评测中心发起的“2022 年度网络安全和数据安全优秀案例评选”活动评选结果正式公布。在众多参与案例中&#xff0c;创宇猎幽APT流量监测系统&#xff08;NDR&#xff09;凭借出色的行业场景实践和出众的产品表现力脱颖而出&#xff0c;成功入选“202…

5、score diffusion model

DDIM中遇到的Score-based SDE这里采用表示神经网络的预测值&#xff0c;用表示。同时等价于DDPM回顾贝叶斯公式原始公式前向过程表示连乘反向过程由前向过程可知&#xff1a;所以&#xff1a;正态分布&#xff1a;重参数技巧&#xff1a;反向过程&#xff1a;优化目标&#xff…

ASP.NETCore学习资料

1.ASP.NETCore比ASP.NET更具优势的地方是什么&#xff1f; ASP.NET Core(ASP.NET Core 简介) ASP.NET Core 是一个跨平台的开源框架&#xff0c;用于在 Windows、macOS 或 Linux 上生成基于云的新式 Web 应用。 ASP.NET(ASP.NET 简介) ASP.NET 是一个成熟的框架&#xff0c;提…

Git学习笔记(七)——其他操作

一、自定义Git Git除了配置user.name 和user.email 还有很多可配置项。 &#xff08;1&#xff09;命令git config --global color.ui true 让Git显示颜色&#xff0c;会让命令输出看起来更醒目.Git 会适当显示不同的颜色。 $ git config --global color.ui true查看分支会有…

延迟队列docker插件

文章目录 目录 文章目录 前言 一、环境准备与使用 总结 前言 一、环境准备与使用 下载对应版本的插件 https://github.com/rabbitmq/rabbitmq-delayed-message-exchange/releases 然后在虚拟机上随便找个文件夹 cd /home/docker 先把容器运行 然后在当前文件下 将插件拷贝…

半入耳式耳机运动会不会掉、佩戴超稳固的运动耳机推荐

现在越来越多的人开始意识到运动的重要性&#xff0c;用运动给身体增加一道“防护墙”是最好的生活方式了&#xff0c;不过&#xff0c;日复一日做着几乎相同的动作&#xff0c;难免索然无味&#xff0c;所以很多人都会选择在运动时戴上耳机听歌解闷&#xff0c;这时候也有不少…

选射频线缆的困难和调试多链路匹配板子的心酸

今日痛点&#xff1a;选电缆和板子出问题 选线缆选到后面&#xff1a;有同事给我说&#xff0c;我还要高精度转接头&#xff0c;我还要BNC转接头 ​ 你们如果知道我选择线缆的艰辛&#xff0c;换做你们会怎么想 附上我选择线缆的心得&#xff1a; 1.S11尽量要考虑桌子的宽度&a…

Vector - CAPL - 文件处理函数

在当前平台化的趋势下,就算是协议层测试依然需要适配各种各样的项目,也需要处理各类型的文件,那我们如何对文件进行读取、写入、修改等类型的操作呢?今天我们就会介绍此类型的函数,主要适用于text、bin文件的处理。 打开文件 Open

MySQL之Explain分析

4 Explain分析&#xff08;重点&#xff09; 4.1 Explain介绍 使用EXPLAIN关键字可以模拟优化器执行SQL语句&#xff0c;分析你的查询语句或是结构的性能瓶颈 在 select 语句之前增加 explain 关键字&#xff0c;MySQL 会在查询上设置一个标记&#xff0c;执行查询会返回执行…

TCP的11种状态

CLOSED状态&#xff1a;初始状态&#xff0c;表示TCP连接是“关闭的”或者“未打开的”LISTEN状态&#xff1a;表示服务端的某个端口正处于监听状态&#xff0c;正在等待客户端连接的到来SYN_SENT状态&#xff1a;当客户端发送SYN请求建立连接之后&#xff0c;客户端处于SYN_SE…

Gradle安装配置阿里云

Gradle是一个基于Apache Ant和Apache Maven概念的项目自动化构建开源工具。它使用一种基于Groovy的特定领域语言(DSL)来声明项目设置&#xff0c;也增加了基于Kotlin语言的kotlin-based DSL&#xff0c;抛弃了基于XML的各种繁琐配置。 面向Java应用为主。当前其支持的语言C、J…

数据结构——哈希表

一、哈希表介绍1.1 哈希表初了解哈希表是属于一个数据结构&#xff0c;并不是一个算法哈希表&#xff1a;hashtable&#xff0c;也叫散列表&#xff0c;根据关键码值(Key value)而直接进行访问的数据结构。通过把关键码值映射到表中的一个位置来访问记录&#xff0c;以加快查找…

解析永春堂1300模式为何风靡新零售市场

最近&#xff0c;永春堂1300模式风靡新零售市场&#xff0c;它凭借兼顾大、小、新、老会员&#xff0c;没有沉淀和泡沫等特点&#xff0c;引起市场的热切关注。而永春堂1300模式如此受欢迎的原因&#xff0c;最重要的&#xff0c;还是它丰厚的奖项报酬。永春堂1300直销模式主要…

Spring Boot 实现接口幂等性的 4 种方案

一、什么是幂等性 幂等是一个数学与计算机学概念&#xff0c;在数学中某一元运算为幂等时&#xff0c;其作用在任一元素两次后会和其作用一次的结果相同。 在计算机中编程中&#xff0c;一个幂等操作的特点是其任意多次执行所产生的影响均与一次执行的影响相同。幂等函数或幂…

多态与虚(函数)表

前言续接上回&#xff08;继承&#xff09;&#xff0c;我们了解了继承是如何通过虚基表&#xff0c;来解决派生类和父类有相同的成员变量的情况&#xff0c;但是类和对象中可不只有成员变量&#xff0c;如果成员函数也有同名&#xff0c;更或者如果我们想在访问不同情况&#…

Zeppelin【部署 01】Zeppelin最新版本zeppelin-0.10.1下载安装配置启动及问题处理(一篇学会部署Zeppelin)

1.简单介绍 来自百度百科&#xff1a; Apache Zeppelin 是一个让交互式数据分析变得可行的基于网页的开源框架。提供了数据分析、数据可视化等功能。是一个提供交互数据分析且基于Web的笔记本。方便你做出可数据驱动的、可交互且可协作的精美文档&#xff0c;并且支持多种语言…

JavaScript 简单计算

parseFloat和Number parseFloat()并不能进行数据类型转换&#xff0c; 所以对字符串进行parseFloat()是不起作用的&#xff0c; 需要使用Number()进行强制类型转换&#xff1b; 但是&#xff0c;如果真正涉及到精度计算&#xff0c;建议用decimal.js 毕竟&#xff0c;js的…

深入理解Linux进程

进程参数和环境变量的意义一般情况下&#xff0c;子进程的创建是为了解决某个问题。那么解决问题什么问题呢&#xff1f;这个就需要进程参数和环境变量来进行决定的。子进程解决问题需要父进程的“数据输入”(进程参数 & 环境变量)设计原则&#xff1a;3.1 子进程启动的时候…

项目实战典型案例6——没有复用思想

这里写目录标题一&#xff1a;背景介绍反例思路&方案反例一的优化思路和方案反例一优化的模拟代码测试优化之前的缺点与优化之后的优点反例二的优化思路和方案反例二优化的模拟代码测试优化之前的缺点与优化之后的优点四&#xff1a;总结一&#xff1a;背景介绍 本篇博客是…