Win7系统如何高效使用内存

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Win7系统如何高效使用内存相关的知识,希望对你有一定的参考价值。

参考技术A

  现今使用Windows7系统的用户量非常的多,正因Windows7的功能强大,界面绚丽对系统内存的要求也是比较高的,所以我们要有效的管理系统内存,让内存在Windows7系统下高效的使用,也是正是很多用户关心的事情,下面我就为大家介绍几个Windows7系统下高效使用内存的几个小 经验 ,欢迎大家参考和学习。

  经验一、设置合理的虚拟内存

  大家都知道不管在Windows7还是在以往的Windows系统中,虚拟内存都十分重要,虚拟内存可以说是物理内存的一个扩展,系统运行一些大型的程序往往都要把程序运行必要的文件缓存在内存中,而合理的设置虚拟内存,系统会自动把部分文件缓存在额外的虚拟内存中(其实在硬盘上),而不会使物理内存使用殆尽。如何正确设置虚拟内存?

  经验二、学会监视内存

  高效的使用内存还需要学会监视内存的使用量,在Windows7系统中提供了强大的任务管理器,你可以在任务管理器中的【性能】选项卡中很直观的看到内存的使用量,可用内存量,已缓存的内存量,而且还可以在【进程】选项卡中看到每个进程占用的内存数量。对于占用内存比较多,而且我们没有在使用的程序/进程,我们可以释放出来,以达到可用内存量的提升,进而提高系统运行速度。

  经验三、及时释放内存空间

  在Windows7系统中,我们使用系统一段时间后会发现运行速度变慢,那是因为有很多我们运行过的程序都有后台驻留在我们的系统内存中,不管是下载软件也好,网络电视也好各种各样的软件都有一定的驻留手段,如果你不再使用该程序可以在进程中禁止它们,还有一些程序如PPTV PPS之类的软件在设置里是有选项让您设置关闭后台运行的,不安装过多的软件,大家都知道在系统使用了很长久的时间,软件也安装了很多的时候系统会变的很慢,这也是应用程序后台大量驻留系统内存的一个表现。

  经验四、优化内存中的数据

  1、桌面上不要设置太多图标,特别是不要放一些体积较大的图像文件如CDR之类的文件,往往这类文件会生成缩略图,而生成缩略图的过程是要调用应用程序的,肯定会占用不少内存,记住保持一个良好的桌面是一个好习惯。

  2、如果内存资源较为紧张,可以考虑使用一些绿色软件,减少程序驻留内存的机会。

  3、平常在开文件或者网页的时候,尽量少开窗口,不用的窗口记得关闭。

  4、系统性能的下降时可以考虑重新启动计算机;

  经验五、提高硬件性能

  在Windows7系统中,提高硬件水平显的尤为重要,内存能否高较使用跟别的硬件关系也非常大,比如你使用集成显卡,那么显存就会在你的内存中划走,可用内存必然减少;如果你的CPU性能不佳,也会加重内存的负担,同样的硬盘也是一样的道理。所以有的朋友为什么说我内存都升级4G了为什么系统还是那么慢,系统的总体速度,内存使高效率还需要一套协调的硬件来支持。

  以上是脚本之家 总结 的几条提高Windows7系统内存使用效率的经验就分享到这里,希望对大家有所帮助。谢谢阅读,希望能帮到大家。

如何在MCU上高效地管理内存?

关注、星标公众,不错过精彩内容

本文主要介绍内存的基本概念以及操作系统的内存管理算法。

一、内存的基本概念

内存是计算机系统中除了处理器以外最重要的资源,用于存储当前正在执行的程序和数据。内存是相对于CPU来说的,CPU可以直接寻址的存储空间叫做内存,CPU需要通过驱动才能访问的叫做外存

二、ROM&RAM&Flash

内存一般采用半导体存储单元,分为只读存储器(ROM,Read Only Memory)、随机存储器(RAM,Random Access Memory)ROM一般只能读取不能写入,掉电后其中的数据也不会丢失。RAM既可以从中读取也可以写入,但是掉电后其中的数据会丢失。内存一般指的就是RAM

ROM在嵌入式系统中一般用于存储BootLoader以及操作系统或者程序代码或者直接当硬盘使用。近年来闪存(Flash)已经全面代替了ROM在嵌入式系统中的地位,它结合了ROM和RAM的长处,不仅具备电子可擦除可编程的特性,而且断电也不会丢失数据,同时可以快速读取数据。

三、两类内存管理方式

内存管理模块管理系统的内存资源,它是操作系统的核心模块之一。主要包括内存的初始化、分配以及释放。

从分配内存是否连续,可以分为两大类。

  • 连续内存管理

为进程分配的内存空间是连续的,但这种分配方式容易形成内存碎片(碎片是难以利用的空闲内存,通常是小内存),降低内存利用率。连续内存管理主要分为单一连续内存管理和分区式内存管理两种

  • 非连续内存管理

将进程分散到多个不连续的内存空间中,可以减少内存碎片,内存使用率更高。如果分配的基本单位是页,则称为分页内存管理;如果基本单位是段,则称为分段内存管理。

当前的操作系统,普遍采用非连续内存管理方式。不过因为分配粒度较大,对于内存较小的嵌入式系统,一般采用连续内存管理。本文主要对嵌入式系统中常用的连续内存管理的分区式内存管理进行介绍。

四、分区式内存管理

分区式内存管理分为固定分区和动态分区

  • 固定分区

    事先就把内存划分为若干个固定大小的区域。分区大小既可以相等也可以不等。固定分区易于实现,但是会造成分区内碎片浪费,而且分区总数固定,限制了可以并发执行的进程数量。

  • 动态分区

根据进程的实际需要,动态地给进程分配所需内存。

五、动态分区内存管理

运作机制

动态分区管理一般采用空闲链表法即基于一个双向链表来保存空闲分区。对于初始状态,整个内存块都会被作为一个大的空闲分区加入到空闲链表中。当进程申请内存时,将会从这个空闲链表中找到一个大小满足要求的空闲分区。如果分区大于所需内存,则从该分区中拆分出需求大小的内存交给进程,并将此拆分出的内存从空闲链表中移除,剩下的内存仍然是一个挂在空闲链表中的空闲分区。

数据结构

空闲链表法有多种数据结构实现,这里介绍一种较为简单的数据结构。每个空闲分区的数据结构中包含分区的大小,以及指向前一个分区和后一个分区的指针,这样就能将各个空闲分区链接成一个双向链表。

内存分配算法

  • First Fit(首次适应算法)

First Fit要求空闲分区链表以地址从小到大的顺序链接。分配内存时,从链表的第一个空闲分区开始查找,将最先能够满足要求的空闲分区分配给进程。

  • Next Fit(循环首次适应算法)

Next Fit由First Fit算法演变而来。分配内存时,从上一次刚分配过的空闲分区的下一个开始查找,直至找到能满足要求的空闲分区。查找时会采用循环查找的方式,即如果直到链表最后一个空闲分区都不能满足要求,则返回到第一个空闲分区开始查找。

  • Best Fit(最佳适应算法)

从所有空闲分区中找出能满足要求的、且大小最小的空闲分区。为了加快查找速度,Best Fit算法会把所有空闲分区按其容量从小到大的顺序链接起来,这样第一次找到的满足大小要求的内存必然是最小的空闲分区。

  • Worst Fit(最坏适应算法)

从所有空闲分区中找出能满足要求的、且大小最大的空闲分区。Worst Fit算法按其容量从大到小的顺序链接所有空闲分区。

  • Two LevelSegregated Fit(TLSF)

使用两层链表来管理空闲内存,将空闲分区大小进行分类,每一类用一个空闲链表表示,其中的空闲内存大小都在某个特定值或者某个范围内。这样存在多个空闲链表,所以又用一个索引链表来管理这些空闲链表,该表的每一项都对应一种空闲链表,并记录该类空闲链表的表头指针。

图中,第一层链表将空闲内存块的大小根据2的幂进行分类第二层链表是具体的每一类空闲内存块按照一定的范围进行线性分段。比如25这一类,以238分为4个内存区间【2525+8),【25+825+16),【25+1625+24),【25+2425+32);216这一类,以214分为4个小区间【216216+214),【216+214216+2*214),【216+2*214216+3*214),【216+3*214216+4*214)。同时为了快速检索到空闲块,每一层链表都有一个bitmap用于标记对应的链表中是否有空闲块,比如第一层bitmap3010,表示25这一类内存区间有空闲块。对应的第二层bitmap0100表示【25+1625+24)这个区间有空闲块,即下面的52Byte

  • Buddysystems(伙伴算法)

Segregated Fit算法的变种,具有更好的内存拆分和回收合并效率。伙伴算法有很多种类,比如BinaryBuddies,Fibonacci Buddies等。Binary Buddies是最简单也是最流行的一种,将所有空闲分区根据分区的大小进行分类,每一类都是具有相同大小的空闲分区的集合,使用一个空闲双向链表表示。BinaryBuddies中所有的内存分区都是2的幂次方。

因为无论是已分配的或是空闲的分区,其大小均为 2 的幂次方,即使进程申请的内存小于分配给它的内存块,多余的内存也不会再拆分出来给其他进程使用,这样就容易造成内部碎片。

当进程申请一块大小为n的内存时的分配步骤为:

1、计算一个i值,使得2i-1<n≤2i

2、在空闲分区大小为2i的空闲链表中查找

3、如果找到空闲块,则分配给进程

4、如果2i的空闲分区已经耗尽,则在分区大小为2i+1的空闲链表中查找

5、如果存在2i+1的空闲分区,则将此空闲块分为相等的两个分区,这两分区就是一对伙伴,其中一块分配给进程,另一块挂到分区大小为2i的空闲链表中

6、如果2i+1的空闲分区还是不存在,则继续查找大小为2i+2的空闲分区。如果找到,需要进行两次拆分。第一次拆分为两块大小为2i+1的分区,一块分区挂到大小为2i+1的空闲链表中,另一块分区继续拆分为两块大小为2i的空闲分区,一块分配给进程,另一块挂到大小为2i的空闲链表中

7、如果2i+2的空闲分区也找不到,则继续查找2i+3,以此类推

内存回收时,如果待回收的内存块与空闲链表中的一块内存互为伙伴,则将它们合并为一块更大的内存块,如果合并后的内存块在空闲链表中还有伙伴,则继续合并到不能合并为止,并将合并后的内存块挂到对应的空闲链表中。

下面的表格对上面6种算法的优缺点进行了比较:

内存算法
优点
缺点
First Fit高地址空间大空闲块被保留低地址空间被不断拆分,造成碎片;每次都从第一个空闲分区开始查找,增加了查找时的系统开销
Next Fit空闲分区分布比较均匀,算法开销小缺乏大内存空闲块
Best Fit用最小内存满足要求,保留大内存空闲块每次分配后所拆分出来的剩余空闲内存总是最小的,造成许多小碎片,算法开销大
Worst Fit每次分配后所拆分出来的剩余空闲内存仍较大,减少小碎片产生缺乏大内存空闲块,算法开销大
TLSF查找效率高,时间复杂度小,碎片问题表现良好内存回收时算法复杂,系统开销大
Buddy systems内部碎片比较严重外部碎片较少

免责声明:本文转自LiteOS物联网操作系统,版权归原作者所有。如涉及作品版权问题,请与我联系删除。

—— The End ——

推荐好文  点击蓝色字体即可跳转

 没想到靠股市,我差点成功逆袭

☞ 分享一下嵌入式 HarmonyOS 的学习思路 

☞ 推荐一款我私藏已久的串口示波神器

☞ 一位老电子工程师的十年职场感悟

☞ 优雅地用宏实现环形缓冲区

欢迎转发、留言、点赞、分享给你的朋友,感谢您的支持!

长按识别二维码关注我

你点的每个好看,我都认真当成了喜欢

以上是关于Win7系统如何高效使用内存的主要内容,如果未能解决你的问题,请参考以下文章

Win7 32位和64位有啥区别?装哪个好?

如何在虚拟机中安装Win7系统

RAMOS系统 WIN7+VHD+GURB map

怎么加载win7.vhd系统镜像到内存运行

大侠们,win7系统总是出现cefmod 已停止工作,如何解决?

在win7的dos下怎样查看各程序占用内存的情况?