前天去网吧跟朋友包宿,导致昨天一整天都报废,今天早上研究了一下nethunter导致手机成功变砖,感冒不停地咳嗽,这些理由应该足够我前两天拖更了吧,下面开始正题

磁盘学习路线

虚拟缓存

虚拟内存

节约内存的编程方式

函数公用

被调用方清理栈

数据压缩

让我们带着问题来学习:

存储程序方式是指什么?

如何通过内存来提高磁盘的访问速度?

windows为例,他为了节约内存用了哪些手段?

首先我们来了解下磁盘这个部件

磁盘是我们电脑中必不可少的硬件,他近几年的发展非常迅猛,但同时磁盘也是我们现在计算机运算速度的瓶颈

我们知道CPU的运算速度是以GHz来计算的,也就是每GHz=10亿次运算,内存也同样是以GHz来计算,但我们的磁盘的运算速度却仅以MB来计算

再来看下磁盘的历史:

最开始的磁盘是软盘,以碟片方式来存储,理论速度可以达到100MB(理论上,现实不成立)

之后发展为现在的SSD芯片式磁盘,民用的运算速度可达到500MB,商用可达到2000MB

磁盘与内存的关系:

电脑中能够存储数据的硬件:

寄存器:存在于CPU的内部,速度最快,容量最少,价格最贵

内存:一般快,一般多,一般贵

磁盘:速度最慢,容量最多,最便宜

电脑执行程序的过程:

CPU向硬盘取出数据,放入寄存器中进行运算,运算结束后放回数据,这是最早的操作方式,但是我们知道硬盘的读取操作非常慢,所以加入了内存这一概念:

程序在使用前从硬盘加载到内存中,cpu在使用时直接访问内存,结束后再讲数据传送到cpu中

以上统称为存储程式计算机,将程序存储在一个固定的地方,运行时加载就可以了

在此之前使用外部介质来存储,典型的是图灵机

但是我们还有一个问题,内存从硬盘中读取数据也要花时间,我们如何节省?

通过磁盘缓存技术:

这里我们分为第一次读取和第二次读取,第一次读取硬盘会同时将数据发送到我们使用数据的地方和内存上,这样在下次使用的时候就会直接访问内存来执行程序

磁盘缓存技术很大程度上解决了访问速度的问题,相当于把内存当做了磁盘使用,我们只需访问一次磁盘下次就可以直接访问内存

磁盘缓存技术的使用范围:win95,98,浏览器,数据库,服务端

但是磁盘并不能一次性的将数据写入到内存上面,因为内存的空间是有限的,这时引入了虚拟内存

虚拟内存:

分为物理内存和虚拟内存

将磁盘中的一块当成内存使用,使cpu在访问有限的内存空间时能够把物理内存和虚拟内存的空间结合起来,最终达到程序的运行目的

举例:

若可用内存5mb

程序运行需:10mb

在磁盘中划分5mb用于加载程序所使用的的内存

cpu向内存调用程序数据中的123,物理内存123与虚拟内存456互换,cpu再次向程序中调用程序数据中的456,程序成功运行

虚拟内存的置换算法:

分页式

分段式

分段式:将需要运行的程序内的逻辑(算法,数据)分段,物理内存只执行当前使用的段,cpu处理完物虚置换,此方法有点类似磁盘缓冲

分页式:将数据做成一页一页(页:一个固定的大小),例如:

10mb=4kb,4kb,4kb......

4kb=一页

以页为单位,在虚拟内存和物理内存间进行交互

小白的CTF学习之路7——内存与硬盘的更多相关文章

  1. 小白的CTF学习之路5——内存的逻辑结构

    很衰的一天,各种意料之外的问题,但都挡不住我每日一更的步伐 内存的逻辑结构大致分为以下几种: 数组 栈与队列 链表 二叉树 以上,数组,栈,链表是我这章要说明的 在学习前需要了解的两个问题: 1.内存 ...

  2. 小白的CTF学习之路4——内存

    明天要进行二模考试了,沉住气,加油,能过 内存是学C路上必不可少的一环,一定要非常认真的去学 内存的物理结构: ROM:只读内存——早期的手机 RAM:读写(数据断点既消) DRAM:经常更新 SRA ...

  3. 小白的CTF学习之路2——二进制数据基础与运算(上)

    今天的第二更,被我拖到了傍晚,嘿嘿,二进制这方面让本就数学不好的我很头疼,所以研究了一段时间 在学习之前我们先了解几个问题: 32位是几个字节? 01011100对于十进制是多少? 00001111向 ...

  4. 小白的CTF学习之路8——节约内存的编程方式

    今天第二更,废话不说上干货 上一章我们学习了内存和cpu间的互动方式,了解到内存的空间非常有限,所以这样就需要我们在编程的时候尽可能的节省内存空间,用最少的空间发挥最大的效果,以下是几种节约内存的方法 ...

  5. 小白的CTF学习之路1——程序与CPU

    刚刚注册了这个博客园,尽量保持每日一更(*/ω\*) 今天看了po学院的教学视频,了解了程序是什么,如何在CPU当中工作的等各种之前未曾想过的问题,特此记录,以防忘记 首先我们学习程序与CPU之前需要 ...

  6. 小白的CTF学习之路6——阶段测评

    刚才考了自己一次,下面我把题和答案放到下面 CPU中不含有以下选项中的  C A:     运算器 B:      寄存器 C:     内存 D:     时钟 这是一道送分题,CPU包含以下几种原 ...

  7. 小白的CTF学习之路3——二进制数据基础与运算(下)

    处理了二进制的整数运算,下面我们来进行令人绝望的浮点数运算 我们先来看一下float事列程序: #include<"stdio.sh"> int main() { fl ...

  8. 新手小白的Linux学习之路

    大家好,我是一个零基础的新手小白,在此和大家分享一下新手小白的学习之路.欢迎各位大神指教!谢谢 Linux简介: Linux操作系统诞生于1991年10月,由芬兰赫尔辛基大学的在校生Linus Tor ...

  9. 小白的mapbox学习之路-显示地图

    刚接触mapbox,只是简单记下自己的学习之路,如有错误,欢迎大神指正 1-头部引入链接 2-body中定义一个div块,用来显示地图 3-在script中创建一个map对象,并设置相关参数 mapb ...

随机推荐

  1. Linux命令:let

    语法 let  expr [expr ...] 说明 计算c的算术表达式.详细说明请参考<Bash参考指南-6.5 shell算术运算>

  2. SQL Select 语句小数位数影响计算的准确率的问题

    在财务数据计算中,特别是分摊过程中,0.0001% 和0.00012%看似极小的差异,但是会造成最后求和很大的差异,因此,我们在计算中需要尽可能多的保留占比的小数位数 可以在SELECT CONVER ...

  3. html 分页

    /*列表分页底部按钮*/ div.tablefooter{ color: #4f6d95; } select.pageLength{ border: 1px solid #d0daea; border ...

  4. Django最简单的从请求过程

    1,url匹配,匹配路由,由理由分发器(urls.py)查找用户请求的url对应关系 1,找到业务函数就调用(views.py中的方法)   2,找不到就报404错误,     3,将数据返回给浏览器 ...

  5. vue环境项目启动后因为eslint语法限制报错

    报错太多,截取了一部分. 解决方法找到项目根目录的build 找到webpack.base.conf.js 打开js文件找到下图的位置 再重新启动项目就好了

  6. CMake support in Visual Studio

    Visual Studio 2017 introduces built-in support for handling CMake projects. This makes it a lot simp ...

  7. np.where()命令介绍

  8. PowerScript数据类型及变量

    PowerBuilder的标准数据类型共有14种 数据类型 意    义 示    例 Blob 二进制数据 可存放可变长度的大量数据,如图片,其它类型的文档数据. 如保存位图 Boolean 布尔型 ...

  9. Python中日期和时间格式化输出的方法

    本文转自:https://www.jb51.net/article/62518.htm 本文实例总结了python中日期和时间格式化输出的方法.分享给大家供大家参考.具体分析如下: python格式化 ...

  10. JVM性能优化读后笔记

    java性能优化权威指南读后笔记 三重境界 1.花似雾中看:对于遇到的额问题还看不清,不知道真真假假,是是非非. 2.悠然见南山:虽然刚开始对这个领域还不清楚,但随着时间推移,你对它有许多自己的见解, ...