关于顺序表的和链表的cpu高速存储

    首先在单个计算机里的存储分为带电存储不带电存储,所谓带电存储的意思就是有电才能存储,例如电脑的内存,需要通电之后才能进行存储--主存,而所谓不带电存储就是一些磁盘,硬盘。这些东西能在没有电的情况下进行存储--本地二级存储。还有一种是远程二级存储,分布式文件系统,web网络服务器。例如百度网盘等等,利用网络传输进行存储。

如下图中,主存(包括主存)往上都是带电存储,往下是不带电存储。

在往上还有一些存储,在我们的电脑上还有一些存储--三级缓存寄存器。这几个是围绕在cpu周围的,因为cpu相对于主存存储的速度来说太快了,主存跟不上cpu的处理速度。再cpu处理主存上一些比较少的数据的时候,例如:a+b比较小,他会把a和b加载到寄存器上面,cpu在寄存器完成处理,然后再把结果传回主存里面。但是寄存器比较小,一般只能存储4-8个字节大小的内存,但是寄存器的速度特别快,如果内存再大一点,就要使用高速缓存了。

 

 现在,假设cpu要去分别遍历顺序表和链表,对于cpu对顺序表的访问,假设访问第一个数据的内存位置0x00123400,他会先看这个地址在不在缓存中,在就直接访问,不在就先加载到缓存,在访问。在计算机执行加载这个操作的时候,他不仅仅只是加载这个一个数据的位置,他还要加载这个数据周围的一片空间的数据,而这片空间的大小取决于你的电脑内存。

假设我们加载的是20个字节,当我们访问你的地址不在缓存中的时候,计算机执行加载这个操作,而这个加载不仅仅只加载这个地址的数据,会把后面20个字节的数据都加载过去。

第二次执行的代码逻辑是要访问顺序表里的第二个位置的数据,同样的计算机会先看这个数据在不在缓存区里,在就直接访问,而我们知道,在寻找第一个数据的时候,计算机就把后面的20个字节的内存都加载到缓存中了,所以计算机就直接访问了。以此类推,这个现象会一直发生到计算机寻找第一个数据的预加载的20个字节都加载完。

而反观链表,我们知道链表的每一个字节差不多都是一块独立的空间,而计算机在一个一个地址的寻找的时候也可能出现上面顺序表的情况,但是这种情况很少,也就是说计算机在每一次寻找数据的时候都要过一遍上述计算机的寻找流程。这就是的链表的命中率没有顺序表高了。

这就是顺序表连续的物理空间带来的优势。

### 回答1: 抱歉,由于本模型为语言模型,无法进行画图操作,但我可以为您解释一下相关的概念。 就绪表是用于存储就绪进程的数据结构,通常是一个数组或链表。就绪组是指具有相同优先级的就绪进程组成的队列。 任务控制块(TCB)是用于存储进程或线程信息的数据结构,包含了进程或线程的状态、程序计数器、寄存器等信息。空闲链表是用于存储空闲的TCB的队列。任务链表是用于存储所有进程或线程的队列。 在操作系统初始化之后,就绪表和就绪组为空,任务控制块空闲链表包含了所有的TCB,任务链表为空。当有新的进程或线程创建时,对应的TCB会从空闲链表中取出,加入到任务链表中,并根据其优先级加入到相应的就绪组中。当CPU空闲时,操作系统会从就绪组中选择优先级最高的进程或线程进行调度。 ### 回答2: OSINIT后的就绪表和就绪组是操作系统中用于调度和管理进程的数据结构。 就绪表是一个用于存储系统中所有就绪进程的数据结构。它通常是一个数组,每个数组元素代表一个就绪进程。就绪表中的元素包含了进程的标识符、优先级以及其他相关信息。当一个进程准备好运行时,它将被添加到就绪表中。 就绪组是就绪表的一个子集,它表示当前可以被调度执行的进程。就绪组中的进程已经满足了执行的条件,并且已经准备好被处理器调度执行。通常情况下,就绪组中的进程按照其优先级进行排序,以便操作系统能够选择优先级最高的进程来执行。 任务控制块(TCB)空闲链表是一个用于存储空闲的任务控制块的链表。任务控制块是操作系统用于管理和控制进程的一种数据结构,它包含了进程的所有相关信息,如进程状态、程序计数器、寄存器状态等。当一个进程终止并释放了其任务控制块时,该任务控制块将被添加到空闲链表中,以便其他进程可以重新使用该任务控制块。 任务链表是一个用于存储系统中所有进程的链表。它包含了所有已经创建的进程的任务控制块。任务链表中的每个任务控制块代表一个进程,它们按照创建的时间顺序排列。通过任务链表,操作系统可以遍历检查系统中的所有进程,执行相应的调度和管理操作。 综上所述,画出OSINIT后的就绪表和就绪组,并创建任务控制块空闲链表和任务链表,是操作系统中重要的数据结构,用于管理和控制系统中的进程。这些数据结构的设置和维护对于操作系统的正常运行至关重要。 ### 回答3: OSINIT是操作系统的初始化函数,其目的是进行操作系统的初始化工作,包括创建一组初始任务、初始化就绪表和就绪组,并将这些任务放入任务链表中。 就绪表是用来记录处于就绪状态的任务的数据结构,通常是一个数组或链表。每个任务都有一个对应的任务控制块(Task Control Block, TCB),其中包含了任务的各种属性和状态信息。 就绪组是指处于不同优先级的任务被划分到的组。操作系统通常会根据任务的优先级将其放入不同的就绪组中。就绪组之间可以按照优先级顺序进行调度。 任务控制块空闲链表是用来存储空闲的任务控制块的链表。当一个任务完成或被撤销时,其对应的任务控制块会被释放,并插入到任务控制块空闲链表中,以供下一个任务使用。 任务链表是用来记录所有任务的链表。当操作系统初始化时,会创建一组初始任务,并按照特定的规则将这些任务链接成为任务链表。任务链表可以根据调度算法的需要进行调整。 因此,OSINIT函数的主要作用是初始化就绪表、就绪组、任务控制块空闲链表和任务链表。这些数据结构在操作系统的运行过程中起着重要的作用,用于管理任务的状态和属性,并提供任务调度的依据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

chihiro1122

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值