【reverse】逆向1 数据宽度
【reverse】逆向1 数据宽度
前言
感觉学逆向的都是大佬,正好最近在看java视频的时候,发现讲课的老师居然是从逆向行业转行来的,顿时肃然起敬。于是想在暑假的最后发光发热,把逆向的基础知识学习稳固一下!
学习是跟着b站的滴水逆向学习的
1、前置知识
数学上的数字是没有大小限制的,可以无限大
但是计算机中,受到硬件的制约,数据都是有长度的
计算机中有很多容器,这些容器来装数据
如果容器存不下,计算机直接扔掉
4位宽度
4位宽度表示:假设计算机只能存储4位2进制数

按照这张图,如果我们规定计数是无符号数,那么,从0到F,可算16个数据,并且,如果F上还要加1,那么数据直接溢出为0
如果我们计数是有符号数,分为正数和负数
但是计算机存的就只有16个数据,所以正负分一半,各8个,所以0、1、2、3、4、5、6、7右半部分,我们规定是正数,F、E、D、C、B、A、9、8,左半部分我们规定是负数。

并且F是最大的负数(-1),因为F加上任意正数,都是向右转。
如果只看二进制的话,并且分正负数,我们发现四位二进制,如果是0开头的都是正数,如果是1开头的都是负数
所以是我们人来定义正负、有无符号,计算机十分单纯,只能用01来表示
8位宽度
8位宽度表示:假设计算机只能存储8位2进制数

无符号数: 0 ~ FF(255)
有符号数:
- 正数:0 ~ 7F (127)
- 负数:FF ~ F4 (-1 ~ -128)
只有我们把数看作有符号数,第一位数是1才是负数
16位宽度
16位宽度表示:假设计算机只能存储16位2进制数

32位宽度
32位宽度表示:假设计算机只能存储32位2进制数

几个重要的计量单位
BYRE 字节 8BIT
WORD 字 16BIT 2字节
DWORD 双字 32BIT 4字节
2、二进制的逻辑运算
数字电路都学过:
三种基本逻辑运算:与或非
然后还有比较重要的一个异或
与: and &
或: or |
非: not !
异或: xor ^
逻辑运算的具体应用
1、CPU如何计算4+5=?
4+5
# 4+5计算机是如何操作的?
# 我们人进行二进制计算
0000 0100
0000 0101
---------(我们使用加法,但是计算机不会)
0000 1001
# 计算机进行计算
# 1、异或(相当于不进为的加法)
0000 0100
0000 0101
---------
0000 0001
# 2、与运算(判断进位)
0000 0100
0000 0101
---------
0000 0100
# 3、与运算结果左移一位
0000 0100
---------
0000 1000
# 4、将1和3步骤异或,得到加法正确结果
0000 0001
0000 1000
---------
0000 1001
# 5、与运算(计算机验证是否结果为0)
0000 0001
0000 1000
---------
0000 0000
# 所以最终的结果就是与运算为0的结果的上一个异或运算
4-5
# 计算机没有减法,4-5 = 4 + (-5)
# 计算机中负数使用补码
0000 0100
1111 1011
---------
1111 1111
# 1、异或
0000 0100
1111 1011
---------
1111 1111
# 2、与运算
0000 0100
1111 1011
---------
0000 0000
# 因为与运算结果为0,我们取上一次异或的结果
4x5
本质就是4个5相加
4/5
本质就是算4能减去几个5(加上几个-5)
2、如果想获取某个值的第N位是多少?
如:8F的第3位是什么?
1000 1111
and 0000 0100
-------------
0000 0100
# 通过与第N位相与一个1,来看这一位是多少
# 得到的结果是0,那么测试的这一位就是0,非0就是1
3、最简单的加密算法

3、总结
- 了解计算机如何存储数据
- 了解数据宽度
- 了解正负数、无符号数的本质
- 掌握逻辑运算,并了解计算的本质
4、课后作业
1、为什么八进制数2-5在计算器中的结果是1 777 777 777 777 777 777 775?
我们看8位宽度的图

2-5肯定是个负数,以中间为分界线,FF是最小的负数(-1)
2减去一个5,就是逆时针转动5个单位,转到了FD
FD是-3,所以在计算器中,八进制2-5,16进制得到的是FFFF FFFF FFFF FFFD
【reverse】逆向1 数据宽度的更多相关文章
- C++输入输出进制、数据宽度与对齐、精度、取整
cout<<setw(4)<<setfill('0')<<a<<endl; ////样例输出 a=41输出 0041 1.数的进制 [转载]未完的c++ ...
- c/c++学习系列之取整函数,数据宽度与对齐
浮点数的取整 C/C++取整函数ceil(),floor() double floor(double x); double ceil(double x); 使用floor函数.floor(x)返回的是 ...
- 64位系统/32位系统下/8位CPU的数据宽度
不同的编译器根据不同的 64 位模型有所不同. 比如 Visual C++,从第一个支持 64 位的版本起,一直就是使用 LLP64 内存模型,也就是说,编译出的代码除了 long 和指针是 64 位 ...
- 【reverse】逆向6 JCC
[reverse]逆向6 JCC 前言 我们之前学习的时候讲了,eip寄存器存储的是当前(即将执行的语句的) 指向地址 而我们之前提到的下断点(F2),就和我们编程中的下断点一样,执行到某句汇编指令然 ...
- 【reverse】逆向5 标志寄存器
[reverse]逆向5 标志寄存器 1.引言 通过一个creak.exe文件的爆破,引出现阶段需要学习的知识 2.标志寄存器 标志寄存器有上图这么多个 记住这几个寄存器的位置和名称 下面是6个状态标 ...
- 【reverse】逆向2 寄存器与内存
[reverse]逆向2 寄存器与内存 1.通用寄存器 主要用途其实没必要记下来,因为只是CPU建议你这么做. 寄存器需要按照顺序被下来 32位就是可以存32个0或1 所以存储范围就是0-0xFFFF ...
- 【Assembly】-NO.88.Assembly.2.滴水逆向.1.002-【位运算及基础指令】-
1.0.0 Summary Tittle:[Assembly]-NO.88.Assembly.2.滴水逆向.1.002-[]- Style:Java Series:Log4j Since:2018-0 ...
- 【Linux】-NO.87.Assembly.1.滴水逆向.1.001-【介绍】-
1.0.0 Summary Tittle:[Linux]-NO.87.Assembly.1.滴水逆向.1.001-[基础]- Style:Java Series:Log4j Since:2017-04 ...
- 【NLP】大数据之行,始于足下:谈谈语料库知多少
大数据之行,始于足下:谈谈语料库知多少 作者:白宁超 2016年7月20日13:47:51 摘要:大数据发展的基石就是数据量的指数增加,无论是数据挖掘.文本处理.自然语言处理还是机器模型的构建,大多都 ...
随机推荐
- Python 属性方法、类方法、静态方法、 特殊属性__doc__ (内建属性)
总结:和类的关联性讲:属性方法>类方法>静态方法 属性方法@property:仅仅是调用方式不用+括号. 类方法@classmethod:访问不了累的属性变量,只可以访问类变量. 静态方法 ...
- MimeMessageHelper代码发邮件时,通过客服端登陆到邮箱,在已发送邮件里没有已经通过代码发送的邮件
MimeMessageHelper代码发邮件时,通过客服端登陆到邮箱,在已发送邮件里没有已经通过代码发送的邮件, 这个问题很奇怪,这样的话不能看到通过代码发送的邮件历史记录,所以只好借助秘密抄送了,抄 ...
- React使用css module和className多类名设置
引入样式文件 import styles from './footer.module.css'; 注意: 样式文件名必须要以.module.css结尾 单类名设置 <div className= ...
- jQuery Validate验证(判断)某个字段是否通过验证
jQuery Validate 默认只能判断整个表单是否验证通过,但是有时候我们需要对某个字段进行判断 ,可以使用以下方法 var bool=$("整个form表单的ID").va ...
- SpringBoot整合quartz实现动态启动,停止定时任务功能
注意:这个方法当程序重启之后会失效,所以必须将定时任务持久化到数据库,然后程序启动的时候重新把数据库的定时任务加载到quartz中 springboot程序启动初始化代码参考:https://www. ...
- 【LeetCode】694. Number of Distinct Islands 解题报告 (C++)
作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 DFS 日期 题目地址:https://leetcod ...
- spoj-ORDERS - Ordering the Soldiers
ORDERS - Ordering the Soldiers As you are probably well aware, in Byteland it is always the military ...
- 1122 机器人走方格 V4
1122 机器人走方格 V4 基准时间限制:1 秒 空间限制:131072 KB 四个机器人a b c d,在2 * 2的方格里,一开始四个机器人分别站在4个格子上,每一步机器人可以往临近的一个格子 ...
- 1002 - Country Roads(light oj)
1002 - Country Roads I am going to my home. There are many cities and many bi-directional roads betw ...
- 使用.NET 6开发TodoList应用(13)——实现查询分页
系列导航及源代码 使用.NET 6开发TodoList应用文章索引 需求 查询中有个非常常见的需求就是后端分页,实现的方式也不算复杂,所以我们本文仅仅演示一个后端查询分页的例子. 目标 实现分页查询返 ...