小白的CTF学习之路8——节约内存的编程方式
今天第二更,废话不说上干货
上一章我们学习了内存和cpu间的互动方式,了解到内存的空间非常有限,所以这样就需要我们在编程的时候尽可能的节省内存空间,用最少的空间发挥最大的效果,以下是几种节约内存的方法:
函数共用
被调用方清理栈
数据压缩
函数公用:
假设有两个程序a,b,他们中有一个共同的代码都是用来发出显示指令的,这样就用了双倍的内存空间
windows有一个dll(动态加载)工具,把很多共有的指令集合到了一起,这样在软件需要的时候只需用函数调用就可以了,省去了写一长串代码的麻烦
被调用方清理栈:
这里引入了栈的概念,栈存放在内存区域,用于计算,存储一些临时使用的值,例如程序计算所产生的临时值,使用完需要回收
清理栈在什么时候完成?
答:在一个函数被调用后
windows由stdcall来做栈,其他方式要用一次声明一次
内存的物理结构:
扇区——>磁道(磁盘中的圆圈)
读写用簇的方式进行
一簇=一个扇区(早年)
簇:windows对于磁盘读写的单位,会根据磁盘大小而改变,簇与磁盘大小成正相关
一个扇区=512个字节
若存一个小于512b的文件,它会变成512b(byte)
1簇里不能有相同的文件
数据压缩:(节约磁盘)
RLE压缩算法
从数据来看:
AAAAAABBCCCDDDD
压缩后:A6B2C3D4
但是此种压缩方式有致命弱点
若:AAAA 4444 则会压缩成 A444,但这种压缩结果是错误的
所以RLE可以压缩图像(传真类型),EXE文件,但是无法压缩文本
文本压缩使用哈夫曼算法(很复杂,简单说)
大致原理:先找出出现的频率
例如:A:200 D::50 C:221
分别使用编码的方式,最短编码如1
按差进行编码,将编码方案与位数计算出来
使用电报的方式将常用编号做成短的,不常用的做成长的
最高压缩率能达到10%
以上所述为可逆压缩(可还原)
不可逆压缩(JPEG图片格式)会损坏文件
固态硬盘原理:本身没有改变,在磁盘扇区进行改变,通过类似集成IC操作,也是以出的方式读取,与U盘原理除通道不同其他一模一样
混合硬盘:有磁盘结构,还有一个IC比磁盘快,作为磁盘缓存
read磁盘阵列:
将数据分为几种块,使几种块同步读取,可理解为最早的分布式
小白的CTF学习之路8——节约内存的编程方式的更多相关文章
- 小白的CTF学习之路2——二进制数据基础与运算(上)
今天的第二更,被我拖到了傍晚,嘿嘿,二进制这方面让本就数学不好的我很头疼,所以研究了一段时间 在学习之前我们先了解几个问题: 32位是几个字节? 01011100对于十进制是多少? 00001111向 ...
- 小白的CTF学习之路7——内存与硬盘
前天去网吧跟朋友包宿,导致昨天一整天都报废,今天早上研究了一下nethunter导致手机成功变砖,感冒不停地咳嗽,这些理由应该足够我前两天拖更了吧,下面开始正题 磁盘学习路线 虚拟缓存 虚拟内存 节约 ...
- 小白的CTF学习之路1——程序与CPU
刚刚注册了这个博客园,尽量保持每日一更(*/ω\*) 今天看了po学院的教学视频,了解了程序是什么,如何在CPU当中工作的等各种之前未曾想过的问题,特此记录,以防忘记 首先我们学习程序与CPU之前需要 ...
- 小白的CTF学习之路5——内存的逻辑结构
很衰的一天,各种意料之外的问题,但都挡不住我每日一更的步伐 内存的逻辑结构大致分为以下几种: 数组 栈与队列 链表 二叉树 以上,数组,栈,链表是我这章要说明的 在学习前需要了解的两个问题: 1.内存 ...
- 小白的CTF学习之路4——内存
明天要进行二模考试了,沉住气,加油,能过 内存是学C路上必不可少的一环,一定要非常认真的去学 内存的物理结构: ROM:只读内存——早期的手机 RAM:读写(数据断点既消) DRAM:经常更新 SRA ...
- 小白的CTF学习之路6——阶段测评
刚才考了自己一次,下面我把题和答案放到下面 CPU中不含有以下选项中的 C A: 运算器 B: 寄存器 C: 内存 D: 时钟 这是一道送分题,CPU包含以下几种原 ...
- 小白的CTF学习之路3——二进制数据基础与运算(下)
处理了二进制的整数运算,下面我们来进行令人绝望的浮点数运算 我们先来看一下float事列程序: #include<"stdio.sh"> int main() { fl ...
- 新手小白的Linux学习之路
大家好,我是一个零基础的新手小白,在此和大家分享一下新手小白的学习之路.欢迎各位大神指教!谢谢 Linux简介: Linux操作系统诞生于1991年10月,由芬兰赫尔辛基大学的在校生Linus Tor ...
- 小白的mapbox学习之路-显示地图
刚接触mapbox,只是简单记下自己的学习之路,如有错误,欢迎大神指正 1-头部引入链接 2-body中定义一个div块,用来显示地图 3-在script中创建一个map对象,并设置相关参数 mapb ...
随机推荐
- 发布python包
写python程序时常常要导入各种包,使用其中的模块或功能.我们如果有可以复用的功能或模块也可以发布成包,并安装在自己或他人电脑上,以供自己或别人使用.python发布包的步骤如下: 一.首先为模块创 ...
- Alpha冲刺
第一天 日期:2018/6/16 1.今日完成任务情况以及遇到的问题 张天旭:根据系统的需求,完成数据库的设计 周甜甜:完成系统后台登录界面的设计及登录功能的实现 李蕾:完成系统后台首页的设计 张海鑫 ...
- tesseract的编译安装
需要安装: <span style="font-family:'Microsoft YaHei';font-size:14px;">apt-get install au ...
- MYSQL批量删除大量数据
DELETE FROM '表' WHERE '字段'=1 会发现删除失败,因为lock wait timeout exceed的错误: 通过LIMIT参数分批删除,因为如果不用limit,删除大量数据 ...
- Mongodb数据库学习
数据库 MongoDB (芒果数据库) 数据存储阶段 文件管理阶段 (.txt .doc .xls)优点 : 数据可以长期保存 可以存储大量的数据 使用简单 缺点 : 数据一致性差 数据查找修改不方便 ...
- python之集合及其方法---整理集
集合的定义: 由不同元素组成.一组无序排列的可hash值.集合中元素必须是不可变类型 集合的定义方式: 由大括号组成: 每个元素用逗号分隔: 元素书写不是key-value形式: 集合是由不同元素组成 ...
- netty(八) netty中自带channelhandler
SslHandler:负责对请求进行加密和解密,是放在ChannelPipeline中的第一个ChannelHandler HttpClientCodec和HttpServerCodec:HttpCl ...
- requests+django+bs4实现一个web微信的功能
前言: 今天我们利用requests模块+django+bs4浏览器来实现一个web微信的基本功能,主要实现的功能如下 a.实现返回二维码 b.实现手机扫码后二维码变成变成头像 c.实现手机点击登陆成 ...
- charles修改接口返回值
我们在测试app时,如果想看大数据量的展示情况,可以通过charles修改接口返回值来实现. 步骤1:手机连接代理 步骤2:app端请求接口,查看charles抓包情况 步骤3:选择想要修改返回值的接 ...
- oralce 的安装以及plsql的配置的html连接
https://www.cnblogs.com/xkstudy/p/6400738.html