架构师知识梳理(一):计算机硬件

news2025/1/21 15:32:05

目录

计算机硬件组成

CPU

CPU的组成

CPU的功能

校验码

奇偶校验 

CRC

CRC计算案例

指令

指令指行过程

 指令系统

指令系统分类

指令流水线技术

流水线技术相关计算公式

存储

计算机存储系统设计

高速缓存Cache

缓存的局部性原理

地址映射

替换算法 

 关于命中率及平均时间的相关计算

磁盘 

磁盘结构与参数

磁盘调度算法

输入输出

 计算机与外设之间的数据交互

内存与接口地址编址 

总线


计算机硬件组成

计算机的基本硬件系统由运算器控制器存储器输入设备输出设备5 大部件组成。 

  • 运算器、控制器等部件被集成在一起统称为中央处理单元(Central ProcessingUnit,CPU)。CPU 是硬件系统的核心,用于数据的加工处理,能完成各种算术,逻辑运算及控制功能
  •  存储器是计算机系统中的记忆设备,分为内部存储器(内存)外部存储器(硬盘)前者速度高、容量小,一般用于临时存放程序、数据及中间结果。而后者容量大、速度慢,可以长期保存程序和数据。
  • 输入设备和输出设备合称为外部设备(简称外设),输入设备用于输入原始数据及各种命令,而输出设备则用于输出计算机运行的结果。

CPU

CPU的组成

CPU的组成:CPU 主要由运算器、控制器、寄存器组和内部总线等部件组成。

  • 运算器:执行所有的算术运算,如加减乘除等;执行所有的逻辑运算并进行逻辑测试,如与、或、非、比较等。组成部分如下:
    • 算术逻辑单元ALU实现对数据的算术和逻辑运算
    • 累加寄存器AC运算结果或源操作数的存放区
    • 数据缓冲寄存器DR暂时存放内存的指令或数据
    • 状态条件寄存器PSW保存指令运行结果的条件码内容,如溢出标志等
  • 控制器:控制整个CPU的工作,由以下部分组成:
    • 指令寄存器IR暂存CPU执行指令
    • 程序计数器PC存放指令执行地址
    • 地址寄存器AR保存当前CPU所访问的内存地址。
    • 指令译码器ID分析指令操作码

CPU依据指令周期的不同阶段来区分二进制的指令和数据,因为在指令周期的不同阶段,指令会命令CPU分别去取指令或者数据。

CPU的功能

  1. 程序控制:CPU 通过执行指令来控制程序的执行顺序,这是CPU的重要功能。
  2. 操作控制:一条指令功能的实现需要若干操作信号配合来完成,CPU产生每条指令的操作信号并将操作信号送往对应的部件,控制相应的部件按指令的功能要求进行操作。
  3. 时间控制:CPU 对各种操作进行时间上的控制,即指令执行过程中操作信号的出现时间、持续时间及出现的时间顺序都需要进行严格控制。
  4. 数据处理:CPU通过对数据进行算术运算及逻辑运算等方式进行加工处理4)数据加工处理的结果被人们所利用。所以,对数据的加工处理也是CPU 最根本的任务。
  5. 中断响应:CPU 还需要对系统内部和外部的中断(异常)做出响应,进行相应的处理。

校验码

校验码是一种附加在数据上的代码,用于检测和/或校正数据在传输、存储或处理过程中可能发生的错误。

当数据被写入CPU的寄存器、缓存或内存时,相应的校验码也会被计算并存储。校验码的生成依赖于数据本身,以及所使用的校验算法。

当数据被读取或传输时,CPU会重新计算校验码,并与存储的校验码进行比较。如果两者不匹配,说明数据可能发生了错误。

校验码对于确保CPU的可靠性和稳定性至关重要。它可以减少因数据错误导致的系统崩溃、性能下降或安全问题。

校验码在CPU中主要用于:

  • 寄存器和缓存中的数据保护
  • 指令和数据的传输校验
  • 内存管理单元(MMU)的数据校验
  • 硬件故障诊断和修复

校验码常见类型:

  • 奇偶校验:最简单的校验方法,只能检测奇数个错误。
  • CRC:一种常见的校验方法,可以检测并校正多种错误类型。

奇偶校验 

在编码中增加1位校验位来使编码中1的个数为奇数(奇校验)或者偶数(偶校验),从而使码距变为2。

码距的概念:

就单个编码A:00而言,其码距为1,因为其只需要改变一位就变成另-个编码。在两个编码中,从A码到B码转换所需要改变的位数称为码距,如A:00要转换为B:11,码距为2。一般来说,码距越大,越利于纠错和检错。

例如:

奇校验:编码中,含有奇数个1,发送给接收方,接收方收到后,会计算收到的编码有多少个1,如果是奇数个,则无误,是偶数个,则有误。
偶校验同理,只是编码中有偶数个1,奇偶校验只能检1位错,并且无法纠错。

CRC

使用CRC编码,需要先约定一个生成多项式G(x)。生成多项式的最高位和最低位必须是1。假设原始信息有m位,则对应多项式M(x)。生成校验码思想就是在原始信息位后追加若干校验位,使得追加的信息能被G(x)整除。接收方接收到带校验位的信息,然后用G(x)整除。余数为0,则没有错误;反之则发生错误。

注意: CRC只能检错,不能纠错。

CRC计算案例

题目:

假设原始信息串为10110,CRC的生成多项式为G(x)=x^4+x+1,求CRC 校验码。

  • 原始信息串:10110
  • 生成多项式:G(x)=x4+x+1G(x)=x4+x+1

计算步骤:

  1. 添加0:在原始信息位后面添加与生成多项式阶数相同的0。因为 G(x)G(x) 的阶为4,所以在原始信息串10110后面添加4个0,得到新串101100000

  2. 得到除数:根据生成多项式,将多项式中的x的幂指数存在的位置设为1,不存在的位置设为0。对于 G(x)=x4+x+1G(x)=x4+x+1,x的幂指数为0, 1, 4的位置存在,所以得到除数串10011。

  3. 模2除法:将新串101100000作为被除数,除数为10011,进行模2除法运算(不进位也不借位的除法)。除法过程如下:

                 1 0 0 1
            ___________________
            |               
    1 0 1 1 |  1 0 1 1 0 0 0 0 0
            /  1 0 1 1      
             ——————————————————
                 1 0 1 0 0
                 1 0 0 1 1
             ——————————————————
                     1 1 1 0 0
                     1 0 0 1 1
             ——————————————————
                       1 1 1 1
    

  4. 补齐余数:如果余数的位数小于生成多项式的阶数,需要在余数的左边补齐0。在这个例子中,余数1111是4位,与生成多项式的阶数相同,所以不需要补齐。

  5. 生成最终发送信息串:将余数1111添加到原始信息串10110的后面,得到最终发送的信息串101101111。

  6. 接收方校验:接收方使用相同的生成多项式 G(x)G(x) 对收到的信息进行除法运算。如果余数为0,则信息无误;如果余数不为0,则要求发送方重传。

指令

一条指令由操作码操作数两部分组成,操作码决定要完成的操作操作数指参加运算的数据其所在的单元地址在计算机中,操作要求和操作数地址都由二进制数码表示,分别称作操作码和地址码,整条指令以二进制编码的形式存放在存储器中。

指令指行过程

计算机指令执行过程包括取指令--分析指令--执行指令三个步骤。

  • 取指令
    • 首先将程序计数器PC中的指令地址取出,送入地址总线,CPU依据指令地址去内存中取出指令内容存入指令寄存器IR,对应图上1-4步骤
  • 分析指令
    • 由指令译码器进行分析,分析指令操作码,对应图中5、6步骤
  • 执行指令
    • 取出指令执行所需的源操作数,执行指令内容,对应图中第7步

寻址方法:

  • 指令寻址方式:
    • 顺序寻址方式:当执行一段程序时,是一条指令接着一条指令地顺序执行。
    • 跳跃寻址方式:指下一条指令的地址码不是由程序计数器给出,而是由本条指令直接给出。程序跳跃后,按新的指令地址开始顺序执行。因此,程序计数器的内容也必须相应改变,以便及时跟踪新的指令地址。
  • 指令操作数的寻址方式:
    • 立即寻址方式:指令的地址码字段指出的不是地址,而是操作数本身。
    • 直接寻址方式:在指令的地址字段中直接指出操作数在主存中的地址。
    • 间接寻址方式:指令地址码字段所指向的存储单元中存储的是操作数的地址。
    • 寄存器寻址方式:指令中的地址码是寄存器的编号。
    • 基址寻址方式:将基址寄存器的内容加上指令中的形式地址而形成操作数的有效地址,其优点是可以扩大寻址能力。
    • 变址寻址方式:变址寻址方式计算有效地址的方法与基址寻址方式很相似,它是将变址寄存器的内容加上指令中的形式地址而形成操作数的有效地址。

 指令系统

指令系统分类

指令系统分为复杂指令系统(CISC)精简指令系统(RISC)

  • CISC复杂指令系统:兼容性强,指令繁多、长度可变,由微程序实现;
  • RISC精简指令系统:指令少,使用频率接近,主要依靠硬件实现(通用寄存器、硬布线逻辑控制)

两者间对比

类型指令寻址方式实现方式备注
CISC(复杂指令系统)数量多,使用频率差别大可变长格式支持多种微程序控制技术(微码)研制周期长
RISC(精简指令系统)数量少,使用频率接近,定长格式,大部分为单周期指令,操作寄存器,只有Load/Store操作内存支持方式少增加了通用寄存器;硬布线逻辑控制为主;适合采用流水线优化编译,有效支持高级语言
指令流水线技术

将指令分成不同段,每段由不同的部分去处理,因此可以产生叠加的效果,所有的部件去处理指令的不同段

RISC中的指令流水线技术

  1. 超流水线(Super Pipe Line)技术。它通过细化流水、增加级数和提高主频,使得在每个机器周期内能完成一个甚至两个浮点操作。其实质是以时间换取空间。
  2. 超标量(Super Scalar)技术。它通过内装多条流水线来同时执行多个处理,其时钟频率虽然与一般流水接近,却有更小的CPI。其实质是以空间换取时间。
  3. 超长指令字(Very Long Instruction Word,VLIW)技术。VLIW和超标量都是20世纪80年代出现的概念,其共同点是要同时执行多条指令,其不同在于超标量依靠硬件来实现并行处理的调度,VLIW则充分发挥软件的作用,而使硬件简化,性能提高。
流水线技术相关计算公式

流水线周期概念:指令分成不同执行段,其中执行时间最长的段为流水线周期。

计算内容公式
流水线执行时间1条指令总执行时间 + (总指令条数 - 1) * 流水线周期
流水线吞吐率计算吞吐率即单位时间内执行的指令条数。公式:指令条数 / 流水线执行时间。
流水线的加速比计算不使用流水线执行时间 / 使用流水线执行时间。

存储

计算机存储系统设计

为了解决存储容量、成本、速度之间的矛盾问题,计算机的存储系统采用的分级存储体系。由上到下以此为:

  • 寄存器:CPU内部,成本最高,读取速度最快
  • Cache : 高速缓存,位于CPU与内存之间,之间与CPU交互,容量大于寄存器小于内存,速度大于内存小于寄存器
  • 主存储器:一般指RAM,也就是常说的运行内存,容量大于Cache,速度小于Cache,但大于辅助存储器(磁盘、光盘)
  • 辅助存储器:需要进行IO读取的,一般指磁盘、外置光盘等,成本最低,读写速度最慢,但容量最大

高速缓存Cache

高速缓存Cache用来存储当前最活跃的程序和数据,直接与CPU交互,位于CPU和主存之间,容量小,速度为内存的5-10倍,由半导体材料构成。其内容是主存内存的副本拷贝,对于程序员来说是透明的。

Cache由控制部分和存储器组成,存储器存储数据,控制部分判断CPU要访问的数据是否在Cache中,在则命中,不在则依据一定的算法从主存中替换。 

缓存的局部性原理

总的来说,在CPU运行时,所访问的数据会趋向于一个较小的局部空间地址内,包括下面两个方面:

  • 时间局部性:如果一个数据项正在被访问,那么在近期它很可能会被再次访问,即在相邻的时间里会访问同一个数据项。
  • 空间局部性:在最近的将来会用到的数据的地址和现在正在访问的数据地址很可能是相近的,即相邻的空间地址会被连续访问。

地址映射

在CPU工作时,送出的是主存单元的地址,而应从Cache存储器中读/写信息。这就需要将主存地址转换为Cache存储器地址,这种地址的转换称为地址映像,由硬件自动完成映射,分为下列三种方法:

  • 直接映射

将Cache存储器等分成块,主存也等分成块并编号。主存中的块与Cache中的块的对应关系是固定的,也即二者块号相同才能命中。地址变换简单但不灵活,容易造成资源浪费。

  • 全相连映射

同样都等分成块并编号。主存中任意一块都与Cache中任意一块对应。因此可以随意调入Cache任意位置,但地址变换复杂,速度较慢。因为主存可以随意调入Cache任意块,只有当Cache满了才会发生块冲突,是最小可能发生块冲突的映像方式。

  • 组组相连映射

前面两种方式的结合,将Cache存储器先分块再分组,主存也同样先分块再分组,组间采用直接映像,即主存中组号与Cache中组号相同的组才能命中,但是组内全相联映像,也即组号相同的两个组内的所有块可以任意调换。 

替换算法 

替换算法的目标是让高速缓存Cache获得尽可能高的命中率

  1. 随机替换算法。就是用随机数发生器产生一个要替换的块号,将该块替换出去。
  2. 先进先出算法。就是将最先进入Cache的信息块替换出去。
  3. 近期最少使用算法。这种方法是将近期最少使用的Cache中的信息块替换出去。
  4. 优化替换算法。这种方法必须先执行一次程序,统计Cache的替换情况。有了这样的先验信息,在第二次执行该程序时便可以用最有效的方式来替换。

 关于命中率及平均时间的相关计算

命中率:即当CPU所访问的数据在Cache中时,命中,直接从Cache中读取数据。

设读取一次Cache时间为1ns,若CPU访问的数据不在Cache中,则需要从内存中读取,设读取一次内存的时间为1000ns。若在CPU多次读取数据过程中,有90%命中Cache,则CPU读取一次的平均时间为(90%*1+10%*1000)ns。 

磁盘 

磁盘结构与参数

磁盘有正反两个盘面,每个盘面有多个同心圆,每个同心圆是一个磁道,每个同心圆又被划分为多个扇区,数据就被存放在一个个扇区中。

 磁头首先要寻找到对应的磁道,然后等待磁盘进行周期旋转,旋转到指定的扇区,才能读取到对应的数据,因此,会产生寻道时间和等待时间。公式为:存取时间=寻道时间+等待时间(平均定位时间+转动延迟)。(注意:寻道时间是指磁头移动到磁道所需的时间;等待时间为等待读写的扇区转到磁头下方所用的时间

磁盘调度算法

磁盘数据的读取时间分为寻道时间+旋转时间,也即先找到对应的磁道,而后再旋转到对应的扇区才能读取数据,其中寻道时间耗时最长,需要重点调度,有如下调度算法:

  • 先来先服务FCFS:根据进程请求访问磁盘的先后顺序进行调度。
  • 最短寻道时间优先SSTF:请求访问的磁道与当前磁道最近的进程优先调度,使得每次的寻道时间最短。会产生“饥饿”现象,即远处进程可能永远无法访问。
  • 扫描算法SCAN:又称“电梯算法”,磁头在磁盘上双向移动,其会选择离磁头当前所在磁道最近的请求访问的磁道,并且与磁头移动方向一致,磁头永远都是从里向外或者从外向里一直移动完才掉头,与电梯类似。
  • 单向扫描调度算法CSCAN:与SCAN不同的是,其只做单向移动,即只能从里向外或者从外向里。

输入输出

 计算机与外设之间的数据交互

  • 程序控制(查询)方式CPU主动查询外设是否完成数据传输,效率极低。

  • 程序中断方式:外设完成数据传输后,向CPU发送中断,等待CPU处理数据,效率相对较高。中断响应时间指的是从发出中断请求到开始进入中断处理程序;中断处理时间指的是从中断处理开始到中断处理结束。中断向量提供中断服务程序的入口地址。多级中断嵌套,使用堆栈来保护断点和现场。

  • DMA方式(直接主存存取):CPU只需完成必要的初始化等操作,数据传输的整个过程都由DMA控制器来完成,在主存和外设之间建立直接的数据通路效率很高。在一个总线周期结束后,CPU会响应DMA请求开始读取数据;CPU响应程序中断方式请求是在一条指令执行结束时。

内存与接口地址编址 

内存与接口地址编址主要是指在计算机系统的硬件设计和编程阶段,用来定义和区分内存单元和输入/输出接口的地址空间。

  • 内存与接口地址独立编址方法

内存地址和接口地址是完全独立的两个地址空间访问数据时所使用的指令也完全不同,用于接口的指令只用于接口的读/写,其余的指令全都是用于内存的。因此,在编程序或读程序时很易使用和辨认。这种编址方法的缺点是用于接口的指令太少、功能太弱

  • 内存与接口地址统一编址方法

内存地址和接口地址统一在一个公共的地址空间里,即内存单元和接口共用地址空间优点是原则上用于内存的指令全都可以用于接口,这就大大地增强了对接口的操作功能,而且在指令上也不再区分内存或接口指令。该编址方法的缺点就在于整个地址空间被分成两部分,其中一部分分配给接口使用,剩余的为内存所用,这经常会导致内存地址不连续

总线

总线(Bus),是指计算机设备和设备之间传输信息的公共数据通道。总线是连接计算机硬件系统内多种设备的通信线路,它的一个重要特征是由总线上的所有设备共享,因此可以将计算机系统内的多种设备连接到总线上。

从广义上讲,任何连接两个以上电子元器件的导线都可以称为总线,通常分为以下三类:

  • 内部总线:内部芯片级别的总线,芯片与处理器之间通信的总线。
  • 系统总线:是板级总线,用于计算机内各部分之间的连接,具体分为数据总线(并行数据传输位数)、地址总线(系统可管理的内存空间的大小)、控制总线(传送控制命令)。代表的有ISA总线、EISA总线、PCI总线。
  • 外部总线:设备一级的总线,微机和外部设备的总线。代表的有RS232(串行总线)、SCSI(并行总线)、USB(通用串行总线,即插即用,支持热插拨)。

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

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

相关文章

2024华数杯数学建模竞赛选题建议+初步分析

提示&#xff1a;DS C君认为的难度&#xff1a;C<A<B&#xff0c;开放度&#xff1a;A<B<C。 综合评价来看 A题适合对机械臂和机器人运动学感兴趣的同学&#xff0c;尤其是有一定编程和优化算法基础的同学。不建议非相关专业同学选择。 B题挑战较大&#xff0…

红黑树的概念及应用

参考文章&#xff1a;红黑树c实现 一.红黑树是什么 红黑树是一种自平衡二叉查找树&#xff0c;是计算机科学领域中的一种数据结构&#xff0c;典型的用途是实现关联数组&#xff0c;存储有序的数据。它可以在O(logn)时间内做查找&#xff0c;插入和删除&#xff0c;这里的n是树…

Docker Remote API 未授权访问漏洞

Docker Remote API 未授权访问漏洞 Docker是一个开源的应用容器引擎&#xff0c;让开发者可以打包他们的应用以及依赖包到一个可移植的容器中&#xff0c;然后发布到任何流行的LINUX机器上&#xff0c;也可以实现虚拟化。 Docker swarm 是一个将docker集群变成单一虚拟的docker…

LeetCode刷题笔记 | 643 | 子数组最大平均数 | 双指针 | 滑动窗口 | 数组 | Java | 详细注释 | 三种解法

&#x1f64b;大家好&#xff01;我是毛毛张! &#x1f308;个人首页&#xff1a; 神马都会亿点点的毛毛张 双指针在一定条件下可以转化成滑动窗口&#xff0c;这道题就是个很好的例子 LeetCode链接&#xff1a;643. 子数组最大平均数 I 1.题目描述 给你一个由 n 个元素组成…

SpringMVC 工作流程简述

SpringMVC 工作流程简述 1. 请求接收2. 请求解析3. 查找处理器4. 处理器适配5. 调用处理器6. 处理结果7. 结果传递8. 视图解析9. 视图渲染10. 响应用户 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&#x1f496; #mermaid-svg-xZqkXNPjG0SH5tMA {font-…

经典算法KMP讲解,包含C++解法ACM模式

写在前面&#xff1a;一个人能走的多远不在于他在顺境时能走的多快&#xff0c;而在于他在逆境时多久能找到曾经的自己。——KMP 讲解前置知识模拟next的构建匹配思路匹配字符串构建next数组 模板代码 题目一&#xff1a;KMP字符串题目二&#xff1a;找出字符串中第一个匹配项的…

电脑开机启动项管理小工具,绿色免安装

HiBit Startup Manager 是一款功能强大的启动项管理工具&#xff0c;旨在帮助用户管理和优化计算机的自动启动程序。该软件通过添加或删除应用程序、编辑它们的属性以及管理流程、服务、任务调度程序和上下文菜单来实现这一目标。 HiBit Startup Manager 提供了以下主要功能&a…

Day82 代码随想录打卡|贪心算法篇---K次取反后最大化的数组和

题目&#xff08;leecode T1005&#xff09;&#xff1a; 给你一个整数数组 nums 和一个整数 k &#xff0c;按以下方法修改该数组&#xff1a; 选择某个下标 i 并将 nums[i] 替换为 -nums[i] 。 重复这个过程恰好 k 次。可以多次选择同一个下标 i 。 以这种方式修改数组后…

【C++】第一讲:入门概论

个人主页&#xff1a; 深情秋刀鱼-CSDN博客 C专栏&#xff1a;C程序设计 一、C发展历史 C的起源可以追溯到1979年&#xff0c;当时Bjarne Stroustrup(本贾尼斯特劳斯特卢普&#xff0c;这个翻译的名字不 同的地⽅可能有差异)在⻉尔实验室从事计算机科学和软件⼯程的研究⼯作。…

Linux中NFS配置

文章目录 一、NFS介绍1.1、NFS的工作流程1.2、NFS主要涉及的软件包1.3、NFS的主要配置文件 二、安装NFS2.1、更新yum2.2、安装NFS服务2.3、配置NFS服务器2.4、启动NFS服务2.5、配置防火墙&#xff08;如果启用了防火墙&#xff0c;需要允许NFS相关的端口通过&#xff09;2.6、生…

最新版Sonible Plugins Bundle v2024 winmac,简单智能,持续更新长期有效

一。Sonible Plugins Bundle v2024 win&mac Sonible Plugins Bundle是一款以创作者为中心的智能音频插件系列。这些工具的特点是易于使用&#xff0c;搭配高级处理和优质音质。pure:bundle的所有插件都由sonible的智能插件系列中使用的技术驱动&#xff0c;但在设计时考虑到…

论文解读(13)-StreetCLIP

原文&#xff1a; LEARNING GENERALIZED ZERO-SHOT LEARNERS FOR OPEN-DOMAIN IMAGE GEOLOCALIZATION StreetCLIP Preprint (arxiv.org) 摘要 本文的任务是Image geolocalization&#xff08;图像地理定位&#xff09; predicting the geographic coordinated of origin for …

【Material-UI】异步请求与Autocomplete的高效集成指南

文章目录 一、异步请求的两种用法1. 延迟加载&#xff08;Load on open&#xff09;实现方法 2. 动态搜索&#xff08;Search as you type&#xff09;实现方法 二、性能优化与注意事项1. 请求节流与去抖2. 禁用内置过滤3. 错误处理 三、实际应用案例&#xff1a;Google Maps P…

[数据集][目标检测]肾结石检测数据集VOC+YOLO格式1299张1类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;1299 标注数量(xml文件个数)&#xff1a;1299 标注数量(txt文件个数)&#xff1a;1299 标注…

目标跟踪那些事

目标跟踪那些事 跟踪与检测的区别 目标跟踪和目标检测是计算机视觉中的两个重要概念&#xff0c;但它们的目的和方法是不同的。 目标检测(object Detection)&#xff1a;是指在图像或视频帧中识别并定位一个或多个感兴趣的目标对象的过程 。 目标跟踪(object Tracking)&…

Java面试八股之Spring框架中使用到了哪些设计模式

Spring框架中使用到了哪些设计模式 Spring 框架是一个广泛使用的 Java 应用程序框架&#xff0c;它包含了许多设计模式的实现。以下是一些 Spring 框架中使用的设计模式&#xff1a; 工厂模式 (Factory Pattern) 描述&#xff1a;Spring 使用 BeanFactory 和 ApplicationCon…

深度优先遍历图--DFS

一. 前言 图的遍历定义&#xff1a;从已经给出的连通图中某一顶点出发&#xff0c;沿着一些边访遍图中所有的顶点&#xff0c;使每个顶点仅被访问一次&#xff0c;就叫做图的遍历&#xff0c;它是图的基本运算。 图的遍历实质&#xff1a;找每个顶点的邻接点的过程。 在找顶点…

【C语言】Top K问题【建小堆】

前言 TopK问题&#xff1a;从n个数中&#xff0c;找出最大&#xff08;或最小&#xff09;的前k个数。 在我们生活中&#xff0c;经常会遇到TopK问题 比如外卖的必吃榜&#xff1b;成单的前K名&#xff1b;各种数据的最值筛选 问题分析 显然想开出40G的空间是不现实的&#…

【目标检测实验系列】YOLOv5高效涨点:基于NAMAttention规范化注意力模块,调整权重因子关注有效特征(文内附源码)

1. 文章主要内容 本篇博客主要涉及规范化注意力机制&#xff0c;融合到YOLOv5(v6.1版本&#xff0c;去掉了Focus模块)模型中&#xff0c;通过惩罚机制&#xff0c;调整特征权重因子&#xff0c;使模型更加关注有效特征&#xff0c;助力模型涨点。 2. 简要概括 论文地址&#x…

2024-08-04 C# 中 string 实用技巧级新手常见错误

文章目录 1 方法重载1.1 string.Split()1.2 string.Indexof() 2 方法对比2.1 Contains2.2 Equals2.3 字符串差值 3 StringBuilder4 换行符4.1 推荐做法4.2 换行符混合问题 5 文件路径分隔5.1 推荐做法 6 测试代码6.1 "OnlySplit()" vs "SplitWithTrim()"6.…