小端模式和大端模式_大端序和小端序

字节存储顺序主要分为大端序(Big-endian)和小端序(Little-endian),区别如下

  • Big-endian:高位字节存入低地址低位字节存入高地址
  • Little-endian:低位字节存入低地址高位字节存入高地址

例如,将12345678h写入1000h开始的内存中,以大端序小端序模式存放结果如下

1c47a990b4bda0f3daba9e2a21db5290.png

一般来说,x86系列CPU都是Little-endian字节序,PowerPC通常是Big-endian字节序。

因为网络协议也都是采用Big-endian方式传输数据的,所以有时也把Big-endian方式称为网络字节序

下面通过一个简单的例子继续理解小端序

#include "windows.h"


BYTE b = 0x12;
WORD w = 0x1234;
DWORD dw = 0x12345678;
char str[] = "abcde";

int main(int argc, char* argv[])
{
    byte lb = b;
    WORD lw = w;
    DWORD ldw = dw;
    char* lstr = str;

    return 0;
}

通过visual studio调试一下,转到反汇编查看反汇编代码

可以看到全局变量bwdwstr的地址分别为06AA000h06AA004h06AA008h06AA00Ch。我们在内存窗口查看相应的地址,可以看到对应的数据,上面不同颜色的方框对应不同变量。

face98567bc415d221c2ecf7daac9b16.png

dw这个变量来说,他的地址是06AA008h,可以看到他的数据是0x78 0x56 0x34 0x12,注意小端序是地址高位存储数据的高位,地址低位存储数据的低位

f181f470b031111417e82c25df5aaf4e.png

而字符串“abcde”被保存在一个字符(char)数组str中,字符数组在内存中是连续的,此时向字符数组存放数据,无论是采用大端序还是小端序,存储顺序都相同。

还有另个知识点,就是注意到反汇编代码中的ptr了吗,逆向分析的时候是不是经常看见这个符号,知道他是干什么的吗?

PTR运算符可以重写操作数默认的大小类型,ptr的前面会有类型的声明,比如byte ptr [b(06AA000h)],他的意思从这个地址取一个byte大小的数据。比如byte ptr [dw(06AA008h)] 得到的就是0x78word ptr [dw(06AA008h)] 得到的就是0x5678,以此类推。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值