我自己看,感觉好像一句一句翻译的,写得很是生硬,不如书上写的灵活

0040137E    8B7424 04       MOV ESI,DWORD PTR SS:[ESP+4]
00401382    56              PUSH ESI
00401383    8A06            MOV AL,BYTE PTR DS:[ESI]
00401385    84C0            TEST AL,AL
00401387    74 13           JE SHORT serial.0040139C
00401389    3C 41           CMP AL,41
0040138B    72 1F           JB SHORT serial.004013AC
0040138D    3C 5A           CMP AL,5A
0040138F    73 03           JNB SHORT serial.00401394
00401391    46              INC ESI
00401392  ^ EB EF           JMP SHORT serial.00401383
00401394    E8 39000000     CALL serial.004013D2
00401399    46              INC ESI
0040139A  ^ EB E7           JMP SHORT serial.00401383
0040139C    5E              POP ESI
0040139D    E8 20000000     CALL serial.004013C2
004013A2    81F7 78560000   XOR EDI,5678
004013A8    8BC7            MOV EAX,EDI
004013AA    EB 15           JMP SHORT serial.004013C1
004013AC    5E              POP ESI
004013AD    6A 30           PUSH 30
004013AF    68 60214000     PUSH serial.00402160
004013B4    68 69214000     PUSH serial.00402169
004013B9    FF75 08         PUSH DWORD PTR SS:[EBP+8]
004013BC    E8 79000000     CALL <JMP.&USER32.MessageBoxA>
004013C1    C3              RETN
004013C2    33FF            XOR EDI,EDI
004013C4    33DB            XOR EBX,EBX
004013C6    8A1E            MOV BL,BYTE PTR DS:[ESI]
004013C8    84DB            TEST BL,BL
004013CA    74 05           JE SHORT serial.004013D1
004013CC    03FB            ADD EDI,EBX
004013CE    46              INC ESI
004013CF  ^ EB F5           JMP SHORT serial.004013C6
004013D1    C3              RETN
004013D2    2C 20           SUB AL,20
004013D4    8806            MOV BYTE PTR DS:[ESI],AL
004013D6    C3              RETN

int fun(char *str)
{
 char *temp = str;
 int j = 0;
 int i;
 for( i = 0 ; ; i++ )
 {
  if( temp == '\0' )
  {
   break;
  }
  if( temp < 0x41 )
  {
   //return MessageBoxA(handle , "重试" , "出错" , 30);
  }
  if( temp > 0x5A )
  {
   temp -= 0x20;
  }
 }
 for( i = 0 ; ; i++ )
 {
  if( temp == '\0' )
  {
   break;
  }
  j += (int)temp;
 }
 j = j ^ 0x5678;
 return j;
}

将近半个小时,把一小段简短的汇编代码写成了C语言代码的更多相关文章

  1. 【原创】一段简短的读取libglade的UI文件的Python代码

    准备写一个将Glade/GtkBuilder等格式的UI文件转换成C++代码的python程序 首先完成的是将LIBGlade格式读取至内存中 #!/usr/bin/env python # -*- ...

  2. 软件工程-构建之法 理解C#一小段程序

    一.前言 老师给出的要求: 阅读下面程序,请回答如下问题: 问题1:这个程序要找的是符合什么条件的数? 问题2:这样的数存在么?符合这一条件的最小的数是什么? 问题3:在电脑上运行这一程序,你估计多长 ...

  3. 需要中文版《The Scheme Programming Language》的朋友可以在此留言(内附一小段译文)

    首先给出原著的链接:http://www.scheme.com/tspl4/. 我正在持续翻译这本书,大概每天都会翻译两小时.若我个人拿不准的地方,我会附上原文,防止误导:还有些不适合翻译的术语,我会 ...

  4. 【从零开始搭建自己的.NET Core Api框架】(四)实战!带你半个小时实现接口的JWT授权验证

    系列目录 一.  创建项目并集成swagger 1.1 创建 1.2 完善 二. 搭建项目整体架构 三. 集成轻量级ORM框架——SqlSugar 3.1 搭建环境 3.2 实战篇:利用SqlSuga ...

  5. 半个小时教你写一个装(bi)逼(she)之地图搜租房

    半个小时教你写一个装(bi)逼(she)之地图搜租房 首先需要一个Python3环境,怎么准备我就不多说了,实在不会的出门右转看一下廖雪峰老师的博客. HTML部分 代码来自:高德API+Python ...

  6. 处理TCP连包的一小段代码

    学习网络编程也有一段时间了,一直听说TCP数据会连包,但一直不知道怎么测试好.最近测试了下:发送方使用对列,将发送的数据存入队列,然后开线程,专门发送.发送多包数据之间不延时.在接收方,他们确实连在一 ...

  7. Cookie是存储在客户端上的一小段数据

    背景 在HTTP协议的定义中,采用了一种机制来记录客户端和服务器端交互的信息,这种机制被称为cookie,cookie规范定义了服务器和客户端交互信息的格式.生存期.使用范围.安全性. 在JavaSc ...

  8. 昨天周末晚上没有出去,码了一小段,先留着kangkang。

    昨天周末晚上没有出去,码了一小段,先留着kangkang. import numpy as npimport matplotlibmatplotlib.use('Agg')import matplot ...

  9. IDEA debug启动的时候需要等半个小时甚至更长时间

    debug启动的时候需要等半个小时甚至更长时间 突然有一天发现debug启动不起来了, 在debug时,项目一直会出现 Connected to the VM ,address: 其实这不是debug ...

随机推荐

  1. Swift 环境搭建

    Swift 环境搭建 Swift是一门开源的编程语言,该语言用于开发OS X和iOS应用程序. 在正式开发应用程序前,我们需要搭建Swift开发环境,以便更好友好的使用各种开发工具和语言进行快速应用开 ...

  2. java script 基本函数

    Math.random()    是令系统随机选取大于等于 0.0 且小于 1.0 的伪随机 double 值. 日期时间函数(需要用变量调用):var b = new Date();      // ...

  3. NX二次开发-UFUN单对象选择对话框UF_UI_select_with_single_dialog

    #include <uf.h> #include <uf_ui.h> ], void* user_data, UF_UI_selection_p_t select) { if ...

  4. JS Date Math Number

    Date对象 Date对象和String对象不太一样,定义了一字符串,其实就是一个String对象,就可以直接调用属性和方法. Date对象的使用,必须使用new关键字来创建,否则,无法调用Date对 ...

  5. 剑指offer——06二叉树的下一个节点

    题目描述 给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回.注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针.   题目的意思是,在一颗二叉树的中序遍历中,给出其中一 ...

  6. 「LibreOJ NOI Round #2」签到游戏

    题目 瞎猜一下我们只要\(n\)次询问就能确定出\(\{A_i\}\)来 感受一下大概是询问的区间越长代价就越小,比如询问\([l,n]\)或\([1,r]\)的代价肯定不会超过\([l,r]\) 所 ...

  7. Game of Taking Stones && POJ1259 /// 最大空凸包 几何+DP

    题目大意: 给定n个点 求出这n个点中最大空凸包的面积 只放个模板 一份模板过两题(滑稽 这个讲解够详细了 https://blog.csdn.net/nyroro/article/details/4 ...

  8. WebService接口测试

  9. 深度探索C++对象模型之第二章:构造函数语意学之Default constructor的构造操作

    C++新手一般由两个常见的误解: 如果任何class没有定义默认构造函数(default constructor),编译器就会合成一个来. 编译器合成的的default constructor会显示的 ...

  10. 数据库MySQL--基础查询

    1.查询字段 查询表某字段:select 字段名 from 表名: 查询表内所有字段:select * from 表名: (当字段和关键字重名是用( ` )着重号区分 ) 2.查询常量值 select ...