「计算机网络」数据链路层

news2025/1/18 18:45:52
  • 数据链路层的地位:网络中的主机、路由器等都必须实现数据链路层
  • 信道类型
    • 点对点信道:使用一对一的点对点通信方式
    • 广播信道
      • 使用一对多的广播通信方式
      • 必须使用专用的共享信道协议来协调这些主机的数据发送

使用点对点信道的数据链路层

数据链路和帧

  1. 链路:从一个节点到相邻节点的一段物理线路(有线或无线),中间没有其他交换节点
  2. 数据链路:把通信协议和软件加到链路中,如网络适配器
  3. 帧:数据链路层的协议数据单元

三个基本问题

  1. 封装成帧
    1. 在一段数据的前后分别添加首部和尾部,构成一个帧
    2. 首部和尾部的一个重要作用就是进行帧定界(即确定帧的界限)
    3. 最大传送单元 MTU:规定了所能传送的帧的数据部分长度上限
    4. 控制字符 SOH:放在一帧的最前面,表示帧的首部开始
    5. 控制字符 EOT:放在一帧的末尾,表示帧的结束
  2. 透明传输
    1. 含义:无论发送什么样的比特组合的数据,这些数据都能够按照原样没有差错地通过这个数据链路层
    2. 字节填充/字符填充:发送端的数据链路层在数据中的控制字符SOH/EOT前插入转义字符"ESC"(十六进制编码为1B,二进制为00011011)
  3. 差错检测
    1. 比特差错: 1 → 0 、 1\to0、 10 0 → 1 0\to1 01
    2. 误码率BER:传输错误的比特占所传输比特总数的比率
    3. 循环冗余检测CRC
      1. 在发送端,先把数据划分为组。假定每组 k 个比特
      2. CRC 运算在每组 M 后面再添加供差错检测用的 n 位冗余码,然后构成一个帧发送出去。一共发送 (k + n) 位
      3. 帧检验序列 FCS:在数据后面添加上的冗余码
      4. 仅用循环冗余检验 CRC 差错检测技术只能做到无差错接受

点对点协议PPP

PPP协议的特点

  1. PPP协议应满足的需求
    1. 简单:首要要求
    2. 封装成帧:必须使用特殊的字符作为帧定界符
    3. 透明性:如果数据中碰巧出现了和界定符一样的比特组合时,就要采取有效的措施来解决这个问题(详见3.2.2)
    4. 多种网络层协议:在同一条物理链路上同时支持多种网络层协议
    5. 多种类型链路:能够在多种类型的链路上运行
    6. 差错检测:对接收端收到的帧进行检测,并立即丢弃有差错的帧
    7. 检测连接状态:能够及时自动检测出链路是否处于正常工作状态
    8. 最大传送单元:必须对每一种类型的点对点链路设置最大传送单元 MTU 的标准默认值,促进各种实现之间的互操作性
    9. 网络层地址协商:必须提供一种机制使通信的两个网络层实体能够通过协商知道或能够配置彼此的网络层地址
    10. 数据压缩协商:必须提供一种方法来协商使用数据压缩算法
  2. PPP协议的组成
    1. 一个将IP数据报封装到串行链路的方法
    2. 链路控制协议LCP
    3. 网络控制协议NCP

PPP协议的帧格式

  1. 各字段的意义
    1. 标志字段F:0x7E,首部的第一个字段和尾部的第二个字段,标志一个帧的开始或结束,连续两帧之间只需要用一个标志字段
    2. 地址字段A:0xFF
    3. 控制字段C:0x03
    4. 协议字段
      1. 0x00221:PPP帧的信息字段为IP数据报
      2. 0xC021:信息字段是PPP链路控制协议LCP的数据
      3. 0x8021:网络层控制数据
    5. 尾部第一个字段:使用CRC的帧检测序列FCS
  2. 字节填充
    1. 当PPP使用异步传输时,把转义字符定义为0x7D,使用字节填充
    2. 把每个0x7E字节转变为2字节序列(0x7D,0x5E)
    3. 把每个0x7D字节转变为2字节序列(0x7D,0x5D)
    4. 在每个ASCLL控制字符(数值小于0x20)前加入一个0x7D字节
  3. 零比特填充
    1. 当PPP使用同步传输时,使用零比特填充
    2. 5个连续1后填入0

PPP协议的工作状态

使用广播信道的数据链路层

局域网的数据链路层

  1. 局域网的主要特点
    1. 网络为一个单位所拥有
    2. 地理范围和站点数目均有限
  2. 局域网的主要优点
    1. 具有广播功能,从一个站点可很方便地访问全网
    2. 便于系统的扩展和逐渐地演变,各设备的位置可灵活调整和改变
    3. 提高了系统的可靠性、可用性和生存性
  3. 局域网按网络拓扑分类
    1. 星形网:由于集线器的出现和双绞线大量用于局域网中,星形以太网/多级星形结构的以太网获得广泛应用
    2. 环形网
    3. 总线网
  4. 媒体共享技术
    1. 静态划分信道
      1. 频分复用、时分复用、波分复用、码分复用
    2. 动态媒体接入控制(多点接入)
      1. 随机接入:所有用户可随机地发送信息
      2. 受控接入:用户必须服从一定的控制,如探询(轮询)
  5. 以太网的两个主要标准
    1. DIX Ethernet V2:世界上第一个局域网产品的规约
    2. IEEE 802.3:第一个IEEE的以太网标准
    3. 局域网数据链路层
      1. 逻辑链路控制LLC:与传输媒体无关
      2. 媒体接入控制MAC:与传输媒体有关
  6. 适配器的作用
    1. 计算机与外界局域网的连接是通过适配器
    2. 重要功能
      1. 进行串行/并行转换
      2. 对数据进行缓存
      3. 在计算机的操作系统安装设备驱动程序
      4. 实现以太网协议

CSMA/CD协议

  1. 最早的以太网:计算机连接到一根总线上
  2. 总线
    1. 优点:易于实现广播通信,简单、可靠
    2. 缺点:多个站点同时发送时,会产生发送碰撞或冲突,导致发送失败
  3. 为通信的方便,以太网采取了两种措施
    1. 采用较为灵活的无连接的工作方式
      1. 不必先建立连接就可以直接发送数据
      2. 对发送的数据帧不进行编号,也不要求对方发回确认
    2. 以太网发送的数据都使用曼彻斯特编码的信号
      1. 缺点:所占的频带宽度比原始的基带信号增加了一倍
  4. CSMA/CD协议(载波监听多点接入/碰撞检测)
    1. 多点接入:总线型网络
    2. 载波监听:即“边发送边监听”。不管在想要发送数据之前,还是在发送数据之中,每个站都必须不停地检测信道
    3. 碰撞检测:适配器边发送数据,边检测信道上的信号电压的变化情况。电压摆动值超过一定的门限值时,就认为总线上至少有两个站同时在发送数据,表明产生了碰撞(或冲突)
    4. 电磁波在1km的电缆的传播时延约为5μs
    5. 争用期(碰撞窗口)
      1. 以太网的端到端往返时延 2τ(τ为单程端到端的传播时延)
      2. 具体争用期时间为51.2μs
        1. 10Mbit/s的以太网
        2. 以太网最大端到端单程时延必须小于争用期的一半 (即 25.6 μs),相当于以太网的最大端到端长度约为 5 km
    6. 碰撞后的重传机制
      1. 采用截断二进制指数退避确定
      2. 发生碰撞的站停止发送数据后,要退避一个随机时间后再发送数据
      3. 基本退避时间2τ
      4. 从整数集合 [ 0 , 1 , … , ( 2 k − 1 ) ] [0, 1, … , (2^k - 1)] [0,1,,(2k1)] 中随机地取出一个数,记为 r
      5. 重传所需的时延 r ∗ 基本退避时间 r*基本退避时间 r基本退避时间
      6. 参数 k = Min[重传次数, 10]
      7. 当重传达 16 次仍不能成功时即丢弃该帧,并向高层报告
    7. 强化碰撞:人为干扰信号
      1. 发送站检测到冲突后,立即停止发送数据帧,接着就发送 32 或 48 比特的人为干扰信号
      2. 以太网还规定了帧间最小间隔为 9.6 μs

使用集线器的星形拓扑

  1. 每个站到集线器的距离不超过100 m
  2. 特点
    1. 使用电子器件来模拟实际电缆线的工作,因此整个系统仍然像一个传统的以太网那样运行,使用集线器的以太网在逻辑上仍是一个总线网,各工作站使用的还是 CSMA/CD 协议,并共享逻辑上的总线,同一时刻至多只允许一个站发送数据
    2. 很像一个多端口的转发器
    3. 工作在物理层,每个端口仅仅简单地转发比特,不进行碰撞检测
    4. 采用了专门芯片,进行自适应串音回波抵消,减少了近端串音

以太网的信道利用率

  1. 成功发送一个帧需要占用信道的时间是 T 0 + τ T_0 + τ T0+τ ,比帧的发送时间要多一个单程端到端时延 τ
  2. 要提高以太网的信道利用率,就必须减小 τ  与 T 0 T_0 T0 之比
  3. 在以太网中定义了参数 a 以太网单程端到端时延 τ 与帧的发送时间 T 0 T_0 T0 之比: a = τ / T 0 a=τ/T_0 a=τ/T0
    1. a → 0 a \to 0 a0,表示一发生碰撞就立即可以检测出来, 并立即停止发送,因而信道利用率很高
    2. a 越大,表明争用期所占的比例增大,每发生一次碰撞就浪费许多信道资源,使得信道利用率明显降低
    3. 为提高利用率,以太网的参数 a 的值应当尽可能小些
    4. 当数据率一定时,以太网的连线的长度受到限制,否则 t  的数值会太大
    5. 以太网的帧长不能太短,否则 T0 的值会太小,使 a 值太大
  4. 极限信道利用率 S m a x S_{max} Smax S m a x = T 0 T 0 + τ = 1 1 + a S_{max}=\frac{T_0}{T_0+τ}=\frac{1}{1+a} Smax=T0+τT0=1+a1
    1. 只有当参数 a 远小于 1 才能得到尽可能高的极限信道利用率

以太网的MAC层

  1. MAC层的硬件地址
    1. 硬件地址又称物理地址,或MAC地址
    2. IEEE 802 标准为局域网规定了一种 48 位的全球地址(简称为地址)
      1. IEEE 注册管理机构 RA 负责向厂家分配前 3 个字节 (即高 24 位),称为组织唯一标识符 OUI(公司标识符)
      2. 厂家自行指派后 3 个字节 (即低 24 位),称为扩展标识符
      3. 必须保证生产出的适配器没有重复地址
      4. 地址被固化在适配器的 ROM 中
    3. IEEE 规定地址字段的第 1 字节的最低位为 I/G 位
      1. 单个站地址:I/G 位 = 0
      2. 组地址:I/G 位 = 1,用来进行多播
      3. 广播地址:所有 48 位都为 1(全 1)。只能作为目的地址使用
    4. IEEE 把地址字段第 1 字节的最低第 2 位规定为 G/L 位
      1. 全球管理:G/L 位 = 0,厂商向 IEEE 购买的 OUI 都属于全球管理
      2. 本地管理:G/L 位 = 1,这时用户可任意分配网络上的地址
    5. 适配器具有过滤功能
      1. 每收到一个 MAC 帧,先用硬件检查帧中的 MAC 地址
      2. 如果是发往本站的帧则收下,然后再进行其他的处理
        1. 发往本站的帧
          1. 单播帧(一对一)
          2. 广播帧(一对全体)
          3. 多播帧(一对多)
      3. 否则就将此帧丢弃,不再进行其他的处理
      4. 以混杂方式工作的以太网适配器只要“听到”有帧在以太网上传输就都接收下来
  2. MAC帧的格式
    1. 常用的以太网 MAC 帧格式
      1. DIX Ethernet V2 标准
      2. IEEE 的 802.3 标准
    2. 外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
      1. 目的地址:6字节
      2. 源地址:6字节
      3. 类型:2字节,用来标志上一层使用的是什么协议,以便把收到的 MAC 帧的数据上交给上一层的这个协议
      4. 数据(MAC 客户数据):46-1500字节
        1. 当数据字段的长度小于 46 字节时,应在数据字段的后面加入整数字节的填充字段,以保证以太网的 MAC 帧长不小于 64 字节
      5. FCS:4字节
      6. 由硬件在帧的前面插入 8 字节。第一个字段共 7 个字节,是前同步码,用来迅速实现 MAC 帧的比特同步。第二个字段 1 个字节是帧开始定界符,表示后面的信息就是 MAC 帧
    3. 无效的MAC帧
      1. 数据字段的长度与长度字段的值不一致
      2. 帧的长度不是整数个字节
      3. 用收到的帧检验序列 FCS 查出有差错
      4. 数据字段的长度不在 46 ~ 1500 字节之间
      5. 有效的 MAC 帧长度为 64 ~ 1518 字节之间
      • 对于检查出的无效 MAC 帧就简单地丢弃
      • 以太网不负责重传丢弃的帧
    4. IEEE 802.3 MAC 与以太网 V2 MAC 帧格式的区别
      1. 外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
      2. 当“长度/类型”字段值大于 0x0600 时,表示“类型”;小于 0x0600 时,表示“长度”
      3. 当“长度/类型”字段值小于 0x0600 时,数据字段必须装入逻辑链路控制 LLC 子层的 LLC 帧
      4. 在 802.3 标准的文档中,MAC 帧格式包括了 8 字节的前同步码和帧开始定界符

扩展的以太网

在物理层扩展以太网

  1. 使用光纤扩展
    1. 主机使用光纤和一对光纤解调器连接到集线器
  2. 使用集线器扩展
    1. 用多个集线器连成更大的以太网
    2. 优点
      1. 使原来属于不同碰撞域(冲突域)的计算机能够跨碰撞域通信
      2. 扩大了以太网覆盖的地理范围
    3. 缺点
      1. 碰撞域增大了,总的吞吐量未提高
      2. 如果使用不同的以太网技术(如数据率不同),那么就不能用集线器将它们互连起来

在数据链路层扩展以太网

  • 早期使用网桥,现在使用以太网交换机
    1. 网桥:根据 MAC 帧的目的地址对收到的帧进行转发和过滤。或者转发,或者丢弃
    2. 以太网交换机:多端口的网桥;可明显地提高以太网的性能
  1. 以太网交换机的特点
    1. 实质上是一个多接口网桥:通常有十几个或更多的接口
    2. 每个接口都直接与一个单台主机或另一个以太网交换机相连,并且一般都工作在全双工方式
    3. 以太网交换机具有并行性
      1. 能同时连通多对接口,使多对主机能同时通信
      2. 相互通信的主机都独占传输媒体,无碰撞地传输数据
      3. 每一个端口和连接到端口的主机构成了一个碰撞域
    4. 接口有存储器,能在输出端口繁忙时把到来的帧进行缓存
    5. 即插即用。其内部的帧交换表(又称为地址表)是通过自学习算法自动地逐渐建立起来的。这种交换表就是一个内容可寻址存储器CAM
    6. 使用专用的交换结构芯片,用硬件转发,其转发速率要比使用软件转发的网桥快很多
  2. 以太网交换机的自学习功能
    2. 消除回路:生成树协议STP
    1. 不改变网络的实际拓扑,但在逻辑上则切断某些链路,使得从一台主机到所有其他主机的路径是无环路的树状结构,从而消除了兜圈子现象
  3. 从总线以太网到星形以太网
    1. 早期
      1. 采用无源的总线结构
      2. 使用CSMA/CD协议,以半双工方式工作
    2. 现在
      1. 以太网交换机为中心的星形结构
      2. 不使用共享总线,没有碰撞问题,不使用 CSMA/CD 协议,以全双工方式工作。但仍然采用以太网的帧结构

虚拟局域网

  1. 以太网存在的问题
    1. 广播风暴:一个以太网是一个广播域,交换机之间的冗余链路形成广播风暴
    2. 安全问题:交换机每个接口都处于一个独立的碰撞域(或冲突域)中,但所有计算机都处于同一个广播域中
    3. 管理困难
  2. 虚拟局域网VLAN
    1. 利用以太网交换机可以很方便地实现虚拟局域网 VLAN
    2. IEEE 802.1Q 对虚拟局域网 VLAN 的定义:虚拟局域网 VLAN 是由一些局域网网段构成的与物理位置无关的逻辑组,而这些网段具有某些共同的需求。每一个 VLAN 的帧都有一个明确的标识符,指明发送这个帧的计算机是属于哪一个 VLAN
    3. 虚拟局域网其实只是局域网给用户提供的一种服务,并不是一种新型局域网
  3. 虚拟局域网优点
    1. 改善了性能
    2. 简化了管理
    3. 降低了成本
    4. 改善了安全性
  4. 划分虚拟局域网的方法
    1. 基于交换机端口
      1. 最简单、也是最常用的方法
      2. 属于在第 1 层划分虚拟局域网的方法
      3. 缺点:不允许用户移动
    2. 基于计算机网卡的 MAC 地址
      1. 根据用户计算机的 MAC 地址划分虚拟局域网
      2. 属于在第 2 层划分虚拟局域网的方法
      3. 允许用户移
      4. 缺点:需要输入和管理大量的 MAC 地址。如果用户的 MAC 地址改变了,则需要管理员重新配置VLAN
    3. 基于协议类型
      1. 根据以太网帧的第三个字段“类型”确定该类型的协议属于哪一个虚拟局域网
      2. 属于在第 2 层划分虚拟局域网的方法
    4. 基于 IP 子网地址
      1. 根据以太网帧的第三个字段“类型”和 IP 分组首部中的源 IP 地址字段确定该 IP 分组属于哪一个虚拟局域网
      2. 属于在第 3 层划分虚拟局域网的方法
    5. 基于高层应用或服务
      1. 根据高层应用或服务、或者它们的组合划分虚拟局域网
      2. 更加灵活,但更加复杂

高速以太网

100BASE-T 以太网(快速以太网)

  1. 在双绞线上传送 100 Mbit/s 基带信号的星形拓扑以太网
  2. 仍使用 IEEE 802.3 的 CSMA/CD 协议
  3. 1995 定为正式标准:IEEE 802.3u
  4. 特点
    1. 可在全双工方式下工作而无冲突发生
    2. 在全双工方式下工作时,不使用 CSMA/CD 协议
    3. 使用 IEEE 802.3 协议规定的 MAC 帧格式
    4. 保持最短帧长不变,但将一个网段的最大电缆长度减小到 100 米
    5. 帧间时间间隔从原来的 9.6 ms 改为现在的 0.96 ms

吉比特以太网

  1. 特点
    1. 允许在 1 Gbit/s 下以全双工和半双工 2 种方式工作
    2. 使用 IEEE 802.3 协议规定的 MAC 帧格式
    3. 在半双工方式下使用 CSMA/CD 协议,而在全双工方式不使用 CSMA/CD 协议
    4. 与 10BASE-T 和 100BASE-T 技术向后兼容
  2. 吉比特以太网的物理层
    1. 自有以太网
    2. 美国国家标准协会ANSI制定的光纤通道FC
  3. 半双工方式工作的吉比特以太网
    1. 半双工时采用 CSMA/CD,必须进行碰撞检测
    2. 为保持 64 字节最小帧长度,以及 100 米的网段的最大长度,增加了 2 个功能
      1. 载波延伸:将争用时间增大为 512 字节。凡发送的 MAC 帧长不足 512 字节时,就用一些特殊字符填充在帧的后面
      2. 分组突发:当很多短帧要发送时,第 1 个短帧采用载波延伸方法进行填充,随后的一些短帧则可一个接一个地发送,只需留有必要的帧间最小间隔即可。这样就形成可一串分组的突发,直到达到 1500 字节或稍多一些为止

10吉比特以太网(10GbE)和更快的以太网

  1. 特点
    1. 万兆比特
    2. 与 10、100 Mbit/s 和 1 Gbit/s 以太网的帧格式完全相同
    3. 保留了 IEEE 802.3 标准规定的以太网最小和最大帧长
    4. 只使用光纤作为传输媒体
    5. 只工作在全双工方式,没有争用问题,不使用 CSMA/CD 协议
  2. 端到端的以太网传输
    1. 以太网的工作范围已经扩大到城域网和广域网,实现了端到端的以太网传输
    2. 好处
      1. 技术成熟
      2. 互操作性很好
      3. 在广域网中使用以太网时价格便宜
      4. 采用统一的以太网帧格式,简化了操作和管理

使用以太网进行宽带接入

  1. 特点
    1. 可以提供双向的宽带通信
    2. 可以根据用户对带宽的需求灵活地进行带宽升级
    3. 可以实现端到端的以太网传输,中间不需要再进行帧格式的转换
    4. 不支持用户身份鉴别
  2. PPPoE
    1. 在以太网上运行 PPP
    2. 将 PPP 帧封装到以太网中来传输
    3. 现在的光纤宽带接入 FTTx 都要使用 PPPoE 的方式进行接入
    4. 利用 ADSL 进行宽带上网时,从用户个人电脑到家中的 ADSL 调制解调器之间的连接也使用 RJ-45 和 5 类线,也使用 PPPoE

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

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

相关文章

ubuntu下如何查看显卡及显卡驱动

ubuntu下如何查看显卡及显卡驱动 使用nvidia-smi 工具查看 查看显卡型号nvida-smi -L $ nvidia-smi -L GPU 0: NVIDIA GeForce RTX 3050 4GB Laptop GPU (UUID: GPU-4cf7b7cb-f103-bf56-2d59-304f8996e28c)当然直接使用nvida-smi 命令可以查看更多信息 $ nvidia-smi Mon Fe…

【Ubuntu】在.bashrc文件中误设置环境变量补救方法

这里是vim也不在PATH中了,因为 解决方法就是在输入vim之后提示的vim路径下用vim打开该文件,然后改回来

C++基础入门:掌握核心概念(超全!)

C作为一门广泛使用的编程语言,以其高性能和灵活性在软件开发领域占据重要地位。无论是游戏开发、系统编程还是实时应用,C都是一个不可或缺的工具。本博客旨在为初学者提供C编程语言的核心概念,帮助你建立坚实的基础。 C关键字 C关键字是编程…

SPP改进(多窗口池化)

论文创新点汇总:人工智能论文通用创新点(持续更新中...)-CSDN博客 原来的模型 15年提出 本质: 多个不同大小的池化窗口进行池化 池化窗口越大得到的特征越少 之后再将不同池化窗口得到的特征拼接起来 现在的改进 实现代码 class SPPCSPC(nn.Modul…

【python】网络爬虫与信息提取--Beautiful Soup库

Beautiful Soup网站:https://www.crummy.com/software/BeautifulSoup/ 作用:它能够对HTML.xml格式进行解析,并且提取其中的相关信息。它可以对我们提供的任何格式进行相关的爬取,并且可以进行树形解析。 使用原理:它能…

Linux_线程

线程与进程 多级页表 线程控制 线程互斥 线程同步 生产者消费者模型 常见概念 下面选取32位系统举例。 一.线程与进程 上图是曾经我们认为进程所占用的资源的集合。 1.1 线程概念 线程是一个执行分支,执行粒度比进程细,调度成本比进程低线程是cpu…

LeetCode、739. 每日温度【中等,单调栈】

文章目录 前言LeetCode、739. 每日温度【中等,单调栈】题目链接及分类思路单调栈 资料获取 前言 博主介绍:✌目前全网粉丝2W,csdn博客专家、Java领域优质创作者,博客之星、阿里云平台优质作者、专注于Java后端技术领域。 涵盖技…

python算法之 Dijkstra 算法

文章目录 基本思想:步骤:复杂度:注意事项:代码实现K 站中转内最便宜的航班 Dijkstra 算法是一种用于解决单源最短路径问题的经典算法。该问题的目标是找到从图中的一个固定顶点(称为源点)到图中所有其他顶点…

vue三种路由守卫详解

在 Vue 中,可以通过路由守卫来实现路由鉴权。Vue 提供了三种路由守卫:全局前置守卫、全局解析守卫和组件内的守卫。 全局前置守卫 通过 router.beforeEach() 方法实现,可以在路由跳转之前进行权限判断。在这个守卫中,可以根据用…

C++ Qt框架开发 | 基于Qt框架开发实时成绩显示排序系统(2)折线图显示

对上一篇的工作C学习笔记 | 基于Qt框架开发实时成绩显示排序系统1-CSDN博客继续优化,增加一个显示运动员每组成绩的折线图。 1)在Qt Creator的项目文件(.pro文件)中添加对Qt Charts模块的支持: QT charts 2&#xf…

【动态规划】【中位数】【C++算法】1478. 安排邮筒

# 作者推荐 【深度优先搜索】【树】【图论】2973. 树中每个节点放置的金币数目 本文涉及知识点 动态规划汇总 LeetCode1478. 安排邮筒 给你一个房屋数组houses 和一个整数 k ,其中 houses[i] 是第 i 栋房子在一条街上的位置,现需要在这条街上安排 k…

Linux_文件系统

假定外部存储设备为磁盘,文件如果没有被使用,那么它静静躺在磁盘上,如果它被使用,则文件将被加载进内存中。故此,可以将文件分为内存文件和磁盘文件。 内存文件 磁盘文件 软、硬链接 一.内存文件 1.1 c语言的文件接口 …

波奇学Linux:文件系统

磁盘认识 磁盘被访问的基本单元是扇区-512字节。 磁盘可以看成多个同心圆,每个同心圆叫做磁道,多个扇区组成同心圆。 我们可以把磁盘看做由无数个扇区构成的存储介质。 要把数据存到磁盘,先定位扇区,用哪一个磁头,…

算法沉淀——链表(leetcode真题剖析)

算法沉淀——链表 01.两数相加02.两两交换链表中的节点03.重排链表04.合并 K 个升序链表05.K个一组翻转链表 链表常用技巧 1、画图->直观形象、便于理解 2、引入虚拟"头节点" 3、要学会定义辅助节点(比如双向链表的节点插入) 4、快慢双指针…

高效的工作学习方法

1.康奈尔笔记法 在这里插入图片描述 2. 5W2H法 3. 鱼骨图分析法 4.麦肯锡7步分析法 5.使用TODOLIST 6.使用计划模板(年月周) 7. 高效的学习方法 成年人的学习特点: 快速了解一个领域方法 沉浸式学习方法: 沉浸学习的判据&am…

MATLAB知识点:fibonacci函数(★☆☆☆☆)返回斐波那契数列

​讲解视频:可以在bilibili搜索《MATLAB教程新手入门篇——数学建模清风主讲》。​ MATLAB教程新手入门篇(数学建模清风主讲,适合零基础同学观看)_哔哩哔哩_bilibili 节选自第3章:课后习题讲解中拓展的函数 在讲解第…

C++ //练习 5.12 修改统计元音字母的程序,使其能统计以下含有两个字符的字符序列的数量:ff、fl和fi。

C Primer(第5版) 练习 5.12 练习 5.12 修改统计元音字母的程序,使其能统计以下含有两个字符的字符序列的数量:ff、fl和fi。 环境:Linux Ubuntu(云服务器) 工具:vim 代码块 /****…

学习总结11

KMP算法 全称Knuth-Morris-Pratt算法,是一种字符串匹配算法。该算法的目的是在一个文本串S内查找一个模式串P的出现位置。 KMP算法的核心思想是利用模式串自身的特性来避免不必要的字符比较。算法通过构建一个部分匹配表(也称为next数组)&a…

实景剧本杀小程序:创新体验,沉浸式推理乐趣

随着科技的飞速发展,人们对于娱乐方式的追求也在不断升级。传统的桌面剧本杀游戏已经不能满足玩家的需求,他们渴望更加真实、刺激的游戏体验。正是这种需求推动下,实景剧本杀小程序应运而生,为玩家带来前所未有的推理乐趣。 实景…

【51单片机】利用【时间延迟】的原理规避【按键抖动问题】

前言 大家好吖,欢迎来到 YY 滴单片机系列 ,热烈欢迎! 本章主要内容面向接触过单片机的老铁 本章是51LCD单片机设计的一个环节,完整可前往相应博客查看完整传送门 欢迎订阅 YY滴C专栏!更多干货持续更新!以下…