反汇编—switch

单线表

x64和x86分析类似

标号1的位置要计算出:减去(debug) / 加上(release)第一个case要等于0,因为第一个case在跳转表数组的0下标位置,

标号2的位置计算出最大case公式:10+7=17

通过1和2,可以知道它们应该是连续case,还要判断是否缺项,进入跳转表看

可以看到原本应该是case12和case14的位置显示的是def,故case12和case14缺项,代码如下

switch(Var)
{
    case 10:
    {
        
    }
    case 11:
    {
                        //缺了case12 、case14
    }
    case 13:
    {
        
    }
    case 15:
    {
        
    }
    case 16:
    {
        
    }
    case 17:
    {
        
    }
}

多线表

Release:

首先通过反汇编+标号6、7得知有跳转表,大概就是switch语句。

通过标号1、2、3得知switch被分为3份,大于0xFF,等于0xFF,小于0xFF。

通过标号4、5结合小于0xFF这条分支,我们可以知道两个十分重要的信息,1.eax+0xFFFFFFF6要等于0,即eax = 0xA(最小的case),2.0xA + 0xF4 = 0xFE(最大的case)。

movzx  eax,byte 401148[eax]          jmp  4010b9[eax*4]    

通过上图,在4010b9地址数组里面,下标为4的地方,参数是def_xxxxx,代表是无效地址,实际跳转去switch的结尾,其中下标0、1、2、3,有实际跳转地址,可以知道这条分支有4个case。

通过上面可以知道这条分支有4个case,又通过在401148地址数组里面观察发现有很多4(这个数组就是存放4010b9数组下标的数组),其中下标为 0、1、2的地方,对应4010b9地址数组里面下标为0、1、2的地方,即可以推出 case 0xA、 case 0xB、case 0xC,然后看401148地址数组的最后一个字节是3,代表它在4010b9地址数组的下标,又因为它是401148地址数组的最后一个字节,即0xFE,故是这条分支的最后一个case,把他们转成10进制。

case 10、case 11、case12、case  254

很抱歉,您提供的是反汇编和C语言代码,无法直接给出switch语句的汇编。但是,我们可以根据您提供的信息,简单介绍一下switch语句的汇编实现方式。 在汇编语言中,switch语句通常被转换为一系列的条件分支指令,例如cmp和je指令。具体实现方式取决于编译器和处理器架构。在x86架构中,通常使用跳转表(jump table)来实现switch语句。跳转表是一个数组,其中每个元素都是一个指向代码的指针。当执行switch语句时,程序会计算出一个索引值,然后跳转到跳转表中对应的指针所指向的代码位置。 下面是一个简单的C语言switch语句的示例代码: ```c switch (x) { case 0: // do something break; case 1: // do something else break; default: // do something else break; } ``` 下面是该代码的汇编实现方式: ```assembly cmp eax, 0 je label1 cmp eax, 1 je label2 jmp default_label label1: ; code for case 0 jmp end_switch label2: ; code for case 1 jmp end_switch default_label: ; code for default case end_switch: ; code after switch statement ``` 在上面的汇编代码中,eax寄存器存储了switch语句的条件变量x的值。首先,程序会将eax的值与每个case语句中的常量进行比较,如果相等,则跳转到对应的标签(label1或label2)处执行相应的代码。如果没有匹配的case语句,则跳转到default_label处执行默认代码。最后,程序会跳转到end_switch处执行switch语句后面的代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值