NR RLC(二)相关参数及format

news2025/1/13 15:42:04

欢迎关注同名微信公众号“modem协议笔记”。

实际查看RLC部分log难免要翻协议,查阅最多的就是相关参数的含义,反而RLC具体过程就没有像当初阅读时那样特别关注了。其实清楚RLC参数含义,看38.322就没那么困难。而RLC具体过程往往要用到相关参数,所以这里先看下相关参数含义及结构。这篇主要是RLC PDU,RLC Formats及其参数的含义, 收发过程中用到的变量,常量和定时器的总结,因而本篇笔记都是概念性描述,难免枯燥。

a280f534783145a4bfa7bfa0f90fa09e.png

 RLC PDU可以分为RLC data PDU和RLC control PDU。TM、UM 和 AM RLC entity使用RLC data PDU 来传输上层PDU(即 RLC SDU)。AM RLC entity使用RLC control PDU来执行ARQ过程。

Protocol data units

b6e6629c063842649da86d775e16f889.png

TMD PDU对应的是TM RLC entity传送的PDCP PDU。

UMD PDU 对应的是UM RLC entity传输PDCP PDU。

AMD PDU 对应的是AM RLC entity传输PDCP PDU。

04d5a46655a74b54979d00619640d46b.png

 AM RLC接收端用STATUS PDU通知对端AM RLC成功接收到的RLC data PDU以及AM RLC的接收端检测到丢失的RLC data PDU。

Formats and parameters

f8818e9596bb4410869ecc83295dca89.png

 RLC PDU是一个bit string。下面会用表格表示bit string,其中第一及最高有效位对应的是表格第一行最左边的bit,最后一个及最低有效位对应的是最后一行最右边的bit;通常,bit string是从左到右读取,然后按行的顺序读取。

RLC SDU是按8 bit 的倍数进行的对齐。RLC SDU从第一位开始就包含在RLC PDU 中,如下图示。

fa50caf7a2a54753b811ca725d6968df.png

a1df994bf91e4aed9fde965369194bf7.png 

 TMD PDU的结构很简单,只有Data field 不包含RLC headers。

735c57f0e65848bc80d38a626ccd77ef.png

 UMD PDU由data field和UMD PDU header组成。UMD PDU header也是按照8 bit 进行的对齐。

如果UMD PDU包含的是一个完整的RLC SDU时,UMD PDU header只会包含SI和R field,没有SN,换言之,带SN的UMD PDU 对应的是RLC SDU的segement。

UM RLC entity会根据RRC 层参数配置成 6 bit SN 或 12 bit SN。对于 NR 侧链路通信的组播和广播,仅支持配置 6 bit SN 长度。只有当相应的 RLC SDU 被分段时,UMD PDU header才包含 SN 字段。携带 RLC SDU的第一段UMD PDU 在其header中不会携带 SO field。SO field的长度为 16 bits。

d6f2033efa164697ab4de49c279bf019.png

 AMD PDU 由data字段和 AMD PDU header组成。AMD PDU header是按照8 bit 进行的对齐。

AM RLC entity根据RRC 层参数配置成 12 bit SN 或 18 bit SN。AMD PDU header的长度分别是两个和三个bytes。

AMD PDU header会包含 D/C、P、SI 和 SN。仅当data字段对应的不是 RLC SDU segment的第一段时,AMD PDU header才包含 SO 字段,在这种情况下,SO 对应16 bits。

 

Parameters

9eafe240ce57438187063fed6f58fb58.png

下面是每个字段的定义,参数中的bit 第一个及最高有效位对应是最左边的bit,最后一个及最不重要的位对应的是最右边的bit。除非另有说明,这里的整数是以无符号整数的标准二进制编码进行的。

e25d389e3e1d4b3aaa232dd9fda4624f.png

 Data field对应元素是按照它们到达RLC entity发射端的顺序映射的。

对于 TMD PDU、UMD PDU 和 AMD PDU,Data field大小的粒度是一个byte;最大data field大小对应的是PDCP PDU的最大size。

对于TMD PDU,只有RLC SDU可以映射到TMD PDU 的Data field,即TMD PDU不存在segment。

对于UMD PDU和AMD PDU,RLC SDU或segment都可以映射到Data field。

2d58aea81b894f21839bd99cfcb82879.png

 Sequence Number (SN) field对应12 bits或18 bits,用于指示相关RLC SDU 的SN值,对于AM RLC, sn是以RLC SDU为单位递增的,即每个RLC SDU 有唯一的SN,一个RLC SDU 要进行分段,分段后的每个segment 的SN 和原始的RLC SDU SN 相同;对于UM RLC,segment RLC SDU才会有sn,sn也是逐一递增的,换而言之,完整的RLC SDU 是没有SN的,所以后面UM RLC entity接收端在处理数据时,要考虑UM PDU没有SN的情况。sn的长度由RRC层参数sn-FieldLength配置。另外LTE RLC SN的规定和NR有很大不同,这里就不细说了,以免搞混,对比下38.322和36.322,顺带看下就清楚了。

eac5b230fbf44a8abc458613125a0854.png

 SI field对应 2bits, 不同的value代表RLC SDU的不同情况,'00'代表是一个完整的RLC SDU;'01'代表是RLC SDU 的first segment;‘10’代表RLC SDU的last segment;'11'代表当前的AMD PDU对应的是RLC SDU的中间部分的segment。

9f728cf1df8147cf85fec50249122a2e.png

 SO field对应16 bits,SO field指示的是RLC SDU segment在原始RLC SDU中的位置。具体地,SO字段指示Data field中RLC SDU segment的第一个字节在原始RLC SDU中所对应的位置。原始 RLC SDU的第一个字节用SO 字段值“0000000000000000”表示,即从零开始编号。

b7517e69f7cb4448b68ceea0c2bd8e02.png

 

Data/Control(D/C) field 对应1 bit,用于区分Control PDU(0)和Data PDU(1)。

facb001cc32e4291abb0b4c6a2ce118e.png

 Polling bit:P 字段对应1 bit,代表AM RLC entity发送端是否请求来自其对等 AM RLC entity的STATUS Report,value 0代表不需要Status report,value 1代表需要Status report。

b811b8d1d7ad4a7f92178f13f8dea2e9.png

 R field对应 1bit,发送端要将R 设置为0,接收端也会忽略这个field。

c1eae733d58e4dccaae8f88da0980081.png

CPT field 对应3 bits,用于确定RLC control PDU的类型,只有值'000'有实际意义,对应STATUS PDU。

9882b3378c274371827cb6e8f4f473a7.png

 ACK_SN长度对应12 bits或 18 bits。从STATUS report的发送端来看,ACK_SN 字段指示下一个未收到的 RLC SDU 的 SN,且该 SDU没有在 STATUS PDU 中报告为nack。当 AM RLC entity发送端收到一个 STATUS PDU时,其代表的内容是截至SN = ACK_SN 的RLC SDU为止目前所有收到的RLC SDU,当然要排除报NACK_SN的PDU,其包含具有NACK_SN、SOstart和SOend的部分RLC SDU,具有NACK_SN和NACK_range的RLC SDU以及具有NACK_SN、NACK range、SOstart和SOstart的部分RLC。SDU。很繁琐的一段,后面到STATUS report的生成时,再具体看。

971c0e2184bc4727ac10477d9bb2fbdc.png

 E1 对应1 bit,代表是否后面还会有一些列NACK_SN E1,E2,E3 bit位出现,E1 =0代表不会有,E1=1代表有。

47073ddf5f1745a598a6c0aca1dd964f.png

 NACK_SN对应 12 bits或18 bits,代表接收端当前认为是 lost的RLC SDU 的SN。 

ad0fe5d001484e4ca4b5fc4e77b11888.png

 

E2对应1 bit,用于指示后面是否还会有一系列的SOstart和SOend,E2=0指没有 E2=1指有。

8c23bb54fdbd48f2b7f18c18355c07c3.png

 

E3对应1 bit,用于指示NACK_SN后是否还有NACK range,value 0 代表没有,value 1代表有。

a4dadf34e19a46e38e8dde6f7f06db9b.png

 NACK range field 对应8 bits,通常RLC SDU 连续整段的丢失时,才会用到,代表的是从NACK_SN(包含NACK_SN)开始连续lost RLC SDUs 的数目。

8428111223694d1bbe447ac98efb2c9b.png

 SOstart 字段与 SOend 字段组合在一块使用,SOstart 字段对应16 bits,指示在 AM RLC entity接收端已检测到丢失的 RLC SDU 部分,与NACK_SN=SN相关。 原始 RLC SDU 的第一个字节由 SOstart 字段值“0000000000000000”引用,即编号从零开始。具体地,SOstart字段以字节为单位指示原始RLC SDU内丢失部分的第一字节的位置。

74ed6cd213be4ae1b8f6b7bc31cf190c.png

 当 E3 =0 时,SOend 字段连同SOstart 字段一起用于表示 RLC SDU SN = NACK_SN 在 AM 接收端检测为丢失的部分。

具体地,SOend字段指示原始RLC SDU中以字节为单位的RLC SDU部分的最后一个字节的位置。原始 RLC SDU 的第一个字节由 SOend 字段值“0000000000000000”引用,即编号从零开始。特殊的 SOend 值“1111111111111111” 代表当前丢失的RLC SDU SN 的结尾对应的就是该RLC SDU 最后一个字节。

当E3为1时,SOend字段指示在AM RLC接收端检测到丢失的SN=NACK_SN + NACK range - 1的RLC SDU部分。具体地,SOend字段指示原始RLC SDU中以字节为单位的RLC SDU部分的最后一个字节的位置。原始RLC SDU 的第一个字节由 SOend 字段值“0000000000000000”引用,即编号从零开始。特殊的 SOend 值“1111111111111111”用于指示 RLC SDU 的缺失部分包括到 RLC SDU最后一个字节的所有字节。

 

State variables

82efa704c664499498a5779a085f0e02.png

 这里开始看下AM和UM RLC entity中使用的state variables,这些参数对于查看UE RLC 层数据的收发很重要,读懂这些state variables就很容易看出RLC tx/rx的具体状况。值得注意的是所有state variables和所有counters都是非负整数。

对于 12 bit SN,与 AM 数据传输相关的所有state variables的取值范围为 0~4095,对于18 bit SN,取值范围为 0~262143。RLC协议中包含的与 AM 数据传输相关的状态变量的所有算术运算均受 AM modules的影响(即12 bit SN 对应的最终值=[算术运算的值] modulo 4096 ;18 bit SN对应的最终值=[算术运算的值] modulo 262144),不能超过各自的取值范围。

与UM 数据传输相关的所有状态变量对于 6 bit SN 可以采用 0~63 之间的值,对于 12 bit SN 可以采用 0~4095 之间的值。RLC协议中包含的与 UM 数据传输相关的状态变量的所有算术运算均受 UM modules的影响(即6 bit SN 对应的最终值=[算术运算的值] modulo 64 ;12 bit SN对应的最终值=[算术运算的值] modulo 4096)。

当执行状态变量或 SN值的算术比较时,应使用modulus base运算。

cedcf7abab0e4b8e94f14dd20337c793.png

 

TX_Next_Ack 和 RX_Next 应分别假定为 AM RLC entity的发送端和接收端的modulus base。从所有涉及的值中减去该modulus base,然后执行绝对值比较(例如处于发送window中的SN:RX_Next <= SN < RX_Next + AM_Window_Size 的计算方式为 [RX_Next – RX_Next] mod 2^[sn-FieldLength] <= [SN – RX_Next] mod 2^[sn-FieldLength] < [RX_Next + AM_Window_Size – RX_Next] mod 2^[sn-FieldLength]),其中对于 12 bit SN 和 18 bit SN,sn-FieldLength分别为 12 或 18。

RX_Next_Highest – UM_Window_Size 应假定为接收 UM RLC entity的modulus base。从所有涉及的值中减去该模数基数,然后执行绝对比较(例如 处于接收窗中的SN :RX_Next_Highest– UM_Window_Size) <= SN < RX_Next_Highest 的计算方式为 [(RX_Next_Highest– UM_Window_Size) – (RX_Next_Highest– UM_Window_Size)] mod 2[sn -FieldLength] <= [SN – (RX_Next_Highest– UM_Window_Size)] mod 2[sn-FieldLength] < [RX_Next_Highest– (RX_Next_Highest– UM_Window_Size)] mod 2[sn-FieldLength]),其中 6 bit SN 和 12 bit SN的sn-FieldLength分别为 6 或 12。

01f4b6480a8e4b039deb839d06abc32c.png

 

AM_Window_Size 代表的是AM RLC entity的发送端和接收端 window的size,12 bit SN :AM_Window_Size=2048;18 bit SN:AM_Window_Size=131072。

UM_Window_Size代表的是 UM RLC entity接收端 window的size,用于UM reassemble window的确定,6 bit SN :UM_Window_Size=32;12 bit SN :UM_Window_Size=2048。

 

AM RLC

2ea17144849540e487dc2880042fb19c.png

AM RLC entity 发送端有3个状态变量:

(1) TX_Next_Ack 是代表ack状态的变量,此状态变量保存的是下一个按顺序要接收positive ack的RLC SDU 的SN值,该变量对应的是传输窗的下边缘。初始设置为 0,会在AM RLC entity收到 对RLC SDU 的SN = TX_Next_Ack的positive ack时进行更新。

(2)TX_Next代表的是发送状态的变量,此状态变量保存的是下一个新生成的 AMD PDU 的 SN 值。初始设置为 0,并且每当AM RLC entity构造一个SN= TX_Next 的 AMD PDU 并包含一个 RLC SDU 或一个 last segment RLC SDU 时,该变量就会更新。

(3)POLL_SN 代表Poll 发送状态的变量,在设置 POLL_SN 时,该状态变量保存的提交给MAC层的AMD PDU中最高 SN的值。初始设置为 0。

7ac13c6ad3364d7c80d46bdcbf764002.png

 

上面关于TX_Next的解释,可能会有点疑惑,但是再结合下面这段描述应该就会比较清楚了。

当向MAC层提交包含segment RLC SDU 的 AMD PDU 时,AM RLC entity发送端应将AMD PDU的SN设置为相应RLC SDU的SN。这里可以看出,AMD PDU 的SN对应的是RLC SDU 的SN ,如果RLC SDU存在segment的话,其所有的segment的SN都是相同的。这里也是和LTE AM RLC处理有所不同的地方。

从PDCP收到的RLC SDU后,AM RLC entity应该将其与TX_Next的SN相关联,然后将新生成AMD PDU的SN设置为TX_Next;之后TX_Next +1,指向下一个要产生的SN。 

5a84db7a10c44f0e8804602c69618333.png

 比如上图RLC UL 发送出去了SN 1~6,其中只有SN 2和4 收到了对端RLC 的positive ack,这时候TX_Next_Ack=1 TX_Next=7,接下来通过对端RLC的STATUS PDU 收到了SN 1和5 的positive ack,UE发送了SN=7的RLC AMD PDU,那要更新发送窗,新发送窗的最低边界TX_Next_Ack=3,而TX_Next=8;如果当前RLC向MAC层提交了包含poll的AMD PDU后,AM RLC entity发送端要将 POLL_SN 设置为提交给MAC层的 AMD PDU 中最高 的SN value,即POLL_SN=7。

9c7c6a5f9a3144449e3cf892043503c7.png

 

AM RLC entity 发送端也有3个counter:

(1)PDU_WITHOUT_POLL:初始设置为 0。它计算的是最近的一个poll bit传输以后 UE发送AMD PDUs的数量。

(2)BYTE_WITHOUT_POLL:初始设置为 0。它计算自最近的一个poll bit发送以后 UE发送的data bytes数。上述两个counter 用于RLC 发送端确定何时在AMD PDU中包含poll bit。

(3)RETX_COUNT:计算的是RLC SDU 或 RLC SDU segment的重传次数。每个 RLC SDU 都会维护一个 RETX_COUNT计数器;这个counter不断增加达到配置的maxRetxThreshold,就导致rlc max numRetx进而引起RLF。

ba3793f53d2e4a4a8064fcd4e1a9f633.png

 

(1)maxRetxThreshold:每个AM RLC entity的发送端使用该参数来限制RLC SDU 的重传次数,包括segments。

(2) pollPDU:每个AM RLC entity的发送端使用该参数来触发对每个 pollPDU PDU的poll。

(3) pollByte:每个 AM RLC entity的发送端使用此参数来触发每个pollByte bytes的poll。

当AM RLC entity 发送端 PDU_WITHOUT_POLL >= pollPDU或BYTE_WITHOUT_POLL >= pollByte,就要在AMD PDU 中包含一个poll bit,peer AM RLC接收端收到后,就要出发STATUS report, 具体情况后面再说。下面是RRC层Counter和参数的配置结构。

287d0ded88884342a77f46ea6c62a57c.png

 sn-FieldLength的配置值得关注下, DRB 的sn-FieldLength的值只能通过reconfiguration with sync来改变。网络侧只能为 SRB 配置 SN-FieldLengthAM=size12,DRB 没有上述限制。 

e2b5447a866f4420807479306570169b.png

 如上图实网配置,SRB1和SRB2 的sn-FieldLength都为 size12,而DRB size12和size18 都行。

3b2765ecfb754a65841304fd2c398407.png

 AM RLC entity接收端有4个状态变量:

(1)RX_Next代表接收状态变量,该状态变量保存最近一个按顺序完全接收到RLC SDU SN 的下一个SN值,该变量对应的就是接收收窗的下边缘。初始设置为 0,并且每当AM RLC entity接收到 RLC SDU的SN = RX_Next 时就会更新。

(2)RX_Next_Status_Trigger:t-Reassembly 状态变量,该状态变量保存的是触发 t-Reassembly的 RLC SDU SN 的下一个 SN 值。

(3)RX_Highest_Status代表Max STATUS 传输状态变量,当需要构建 STATUS PDU 时,该状态变量保存的是STATUS PDU中ACK_SN指示的那个SN。初始设置为 0。结合后面构造STATUS PDU ,设置ACK_SN的规定,如上黄色字体,就将ACK_SN 设置为没有在STATUS PDU指示为丢失的SN,这个SN 对应的是下一个没有收到的RLC SDU的SN。

(4)RX_Next_Highest代表的是highest接收状态变量,该状态变量保存的是当前接收到的RLC SDU highest SN 的 下一个SN 值,初始设置为 0。

085dcd6f735b419ab568c0bf2d409bde.png

 假如当前AM RLC 接收端 值收到了SN 1~6 RLC SDU,其中只有2和4收全了,那RX_Next=1,RX_Next_Highest=7,如果这时候收到了peer 发送端的 AMD PDU 带poll bit =1,这时候就要生成STATUS report,根据规定ACK_SN对应的是没有在STATUS PDU中指示为丢失的SN,这个SN 对应的是下一个没有收到的RLC SDU 的SN,具体到这里RX_Highest_Status=7。

 

UM RLC

817249684f68421caa995928b1cfa2c3.png

 UM RLC entity发送端只有一个状态变量:TX_Next代表UM 发送状态变量,此状态变量保存的是下一个新生成的UMD PDU segment的SN值。初始设置为0,并且在UM RLC entity向MAC 提交包括RLC SDU的 last segment的UMD PDU之后才会更新。这里又与AM RLC 的定义有所不同,只有UMD PDU 对应的是RLC SDU segment时才有sn,如果UM PDU对应的是完整的RLC SDU,UMD PDU 是没有sn的。这样的设定 从分析问题的角度看,是十分友好的,网络状况良好的情况下,UL grant十分充足,segment就可能比较少,进而SN的处理会少很多,UE处理起来也会稍微便捷些;网络状况不好的时候,UL grant通常不会给足,这时候segment会比较多,对应的UM PDU大多都会带SN ,在检查UE UL发送和DL接收时,通过SN分析UE收发也更能看出问题。  

UM RLC entity 接收端有3个状态变量:

(1)RX_Next_Reassemble 代表UM 接收状态变量

此状态变量保存的是仍认为在进行reassembly的最早的 SN 值。初始设置为 0。对于 NR sidelink 通信的组播和广播,它初始设置为第一个接收到的包含 SN 的 UMD PDU 的 SN值。

(2)RX_Timer_Trigger 代表UM t-Reassembly 状态变量,保存的是触发t-Reassembly SN的下一个SN的值。

(3)RX_Next_Highest代表UM receive 状态变量,保存的是当前UE收到的UMD PDUs中highest SN的下一个SN值,作为reassembly window的最高边缘,初始设置为0。对于 NR sidelink 通信的组播和广播,它初始设置为第一个接收到的包含 SN 的 UMD PDU 的 SN值。

b32f40a2138446abb10a8469f5ba0af5.png

 

假如RX_Next_Reassembly 仍处于reassembly window [RX_Next_Highest – UM_Window_Size,RX_Next_Highest)的范围,上述场景RX_Next_Reassembly=1,RX_Next_Highest=7。

a3e0cc49fd4445ec90f175fc0e118812.png

 (1) t-PollRetransmit:由 AM RLC entity的发送端用来重传poll使用。

(2) t-Reassembly:由 AM RLC entity和 UM RLC entity的接收端使用,用来检测下层 RLC PDU 的丢失。如果 t-Reassembly 正在运行,则不应额外启动 t-Reassembly,即每个 RLC entity只有一个 t-Reassembly可以在特定时间运行。

(3) t-StatusProhibit:由 AM RLC entity的接收端使用,在运行期间禁止传输 STATUS PDU。

几个Timer 的工作原理,后面再具体看。

到这里本篇就结束。后面会针对RLC具体流程以及实际问题分析过程进行简单总结,但是免不了要再回看上面的这些个参数定义。

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

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

相关文章

azkaban --- 案例实操

目录 案例一 &#xff1a; 输出Hello World 案例二 &#xff1a;作业依赖 案例三 &#xff1a;内嵌工作流 案例四 &#xff1a;自动失败 案例五 &#xff1a;手动失败 案例六 &#xff1a;JavaProcess 案例七 &#xff1a;启动服务 案例八 &#xff1a;Hbase 案例九 …

SpringBoot整合企业微信消息推送(四十五)

从头开始&#xff0c;并不意味着失败&#xff0c;相反&#xff0c;正是拥抱成功的第一步&#xff0c;即使还会继续失败 上一章简单介绍了 SpringBoot整合钉钉消息推送(四十四) , 如果没有看过,请观看上一章 一. 企业微信前期准备 用户需要注册一个企业微信&#xff0c; 并且登…

ANR基础 - Input系统

系列文章目录 提示&#xff1a;这里可以添加系列文章的所有文章的目录&#xff0c;目录需要自己手动添加 例如&#xff1a;第一章 Python 机器学习入门之pandas的使用 文章目录 系列文章目录前言一、Input系统概述二、整体框架1.整体框架类图2.核心启动过程2.1 initialize2.1 I…

浅析一下PTPD

浅聊一下PTPD 文章目录 浅聊一下PTPD1.什么是PTPD2.PTPD源码浅析一下1.src文件1.arith.c2.bmc.c3.constant.h 和 datatypes.h4.display.c5.management.c6.protocol.c7.ptp_datatypes.h8.ptp_primitives.h9.ptp_timers.c10.ptpd.c11.signaling.c12.timedomain.c 2.def文件夹3.de…

ROS:gazebo创建仿真地图,turtlebot3加载仿真地图进行建图,生成yaml和pgm地图信息

一.安装turtlebot3 Ubuntu18.04 实现&#xff1a;安装turtlebot3功能包、虚拟机与机器人之间的网络配置、测试机器人Cartographer建图_Charlesffff的博客-CSDN博客 二.安装gazebo ROS18.04&#xff1a;安装gazebo&#xff0c;下载模型_gazebo下载模型_Charlesffff的博客-CSD…

Linux 设备驱动程序(二)

系列文章目录 Linux 内核设计与实现 深入理解 Linux 内核&#xff08;一&#xff09; 深入理解 Linux 内核&#xff08;二&#xff09; Linux 设备驱动程序&#xff08;一&#xff09; Linux 设备驱动程序&#xff08;二&#xff09; Linux设备驱动开发详解 文章目录 系列文章目…

大型央企集团财务经营分析框架系列(三)

01集团经营管理分析的切入点 集团经营管理分析的切入点往往是从财务分析开始。 往往在一家企业里面&#xff0c;财务方面的信息化建设是要早于其它方面的信息化建设的&#xff0c;业务标准化程度比较高&#xff0c;数据标准化程度也比较高&#xff0c;分析框架也相对成熟。 …

栈和队列的相关功能实现及其基础应用

前言&#xff1a;栈和队列是常见的数据结构&#xff0c;它们在计算机科学中被广泛应用。栈和队列都是一些元素的集合&#xff0c;它们的主要区别在于数据的组织方式和访问顺序。在栈中&#xff0c;元素的添加和删除都在同一端进行&#xff0c;称为栈顶&#xff0c;而在队列中&a…

PMP考试100个主要知识点

1.一个项目在启动阶段会进行量级估算&#xff0c;准确范围是-50至100%。2000版的量级估算准确度为&#xff1a;-25%到75%。 2.质量控制通常先于范围确认执行&#xff0c;但这两个过程可以并列进行参考 3.Cost-plus-fixed-fee(CPFF)成本加固定费用合同。成本补偿型合同包括成本加…

快速入门ChatGPT和AIGC:底层原理、热门工具、行业现状【我们能做什么】

最近大家热议的ChatGPT和AI绘画工具的底层技术原理是什么&#xff1f;是如何发展到现在的&#xff1f;有哪些应用场景、热门工具&#xff1f;AIGC产业上下游有哪些公司&#xff1f;作为普通用户&#xff0c;我们还能接触哪些应用AI技术打造的商业解决方案&#xff1f;…… 我们…

微信小程序 录音+播放组件封装

展示 长按录音 松开结束录音 点击播放 再次点击暂停 再次点击继续播放 展示效果&#xff1a; 录音功能 录音功能&#xff08;手指按下开始录音 手指松开结束录音&#xff09;&#xff1a; 使用wx原生录音功能在 component 外新建 wx.getRecorderManager() RecorderManager…

国巨 :硬件设计基础60条

硬件设计是现代科技发展中至关重要的领域之一。它涵盖了从微电子器件到复杂的系统级设计的各个方面&#xff0c;是现代电子产品的核心。在这篇文章中&#xff0c;我将介绍60个基础概念&#xff0c;这些概念是硬件设计工程师必备的知识&#xff0c;并且是设计出高质量硬件的关键…

【web】学习ajax和fetch

1/什么是ajax ajax 全名 async javascript and XML(异步JavaScript和XML) 是前后台交互的能⼒。 也就是我们客户端给服务端发送消息的⼯具&#xff0c;以及接受响应的⼯具。 在不重新加载整个网页的情况下&#xff0c;对网页的某部分进行更新。而传统的网页(不使用 Ajax)如果需…

设计师必备的5个素材库,马住

今天就告诉大家设计师都是去哪些网站找素材&#xff0c;分享五个网站&#xff0c;解决你80%的设计素材&#xff0c;建议收藏&#xff01; 1、菜鸟图库 https://www.sucai999.com/?vNTYxMjky 这是一个为新手设计师提供免费素材的设计网站&#xff0c;站内有超多平面模板、海报…

成为一名黑客需要学什么

想成为一名专业黑客&#xff0c;但不知道从哪里学起”很多人向盾叔问过这个问题&#xff0c;今天盾叔就为你介绍成为专业黑客必须学习的十个方面的知识&#xff0c;希望能为迷惘中的你指明方向。 一、基本的计算机知识 把它列为第一条&#xff0c;相信很多人肯定会觉得不以为…

Java虚拟机快速入门 | JVM引言、JVM内存结构、直接内存

目录 一&#xff1a;JVM引言 1. 什么是 JVM ? 2. 常见的 JVM 3. 学习路线 二&#xff1a;JVM内存结构 1. 程 序 计 数 器&#xff08;PC Register&#xff09; 2. 虚 拟 机 栈&#xff08;JVM Stacks&#xff09; 3. 本 地 方 法 栈&#xff08;Native Method Stacks&…

Vscode C++环境配置

多文件编译 打开设置搜索coderunner 找到Executor Map 加入-I目录名 目录名/*.cpp 调试 点击调试以后会产生tasks.json文件&#xff0c;加入链接文件和库文件

map用法以及特殊值的情况

map用法以及特殊值的情况 一、map用法的说明 map(callbackFn, thisArg); // callbackFn回调函数&#xff0c;thisArg可选 callbackFn是个回调函数&#xff0c;该回调函数的参数按照顺序为element&#xff08;当前正在处理的元素&#xff09;&#xff0c;index&#xff08;正…

WPF MaterialDesign 初学项目实战(1)首页搭建

前言 最近在学WPF&#xff0c;由于人比较烂&#xff0c;有一个星期没怎么动代码了。感觉有点堕落。现在开始记录WPF项目&#xff0c;使用MaterialDesignInXamlToolkit。 环境搭建 如果没下载MaterialDesign 的源码 github源码运行 在Nuget里面引入MaterialDesign Materia…

数字孪生技术在环境保护领域怎样应用?

近年来&#xff0c;环境保护成为全球范围内的热点话题&#xff0c;各国都在积极探索创新的解决方案。其中&#xff0c;数字孪生技术的出现为环境保护带来了全新的机遇和挑战。数字孪生技术将物理世界与数字世界相结合&#xff0c;通过精确的模拟和实时数据分析&#xff0c;为环…