汇编学习笔记

工具:DTDebug(VT-O)专业版V1.0.025主要有四个窗口:反汇编窗口、寄存器窗口、堆栈窗口、内存窗口。

汇编语言的基础符号

例1. ADD EAX,1往 EAX寄存器里面的数字加1 Mov Eax,0x2将2加入到寄存器EAX当中

(1)  在程序下断点,找到位置【win32 messagebox】堆栈的栈顶存的是当程序调用该函数的时候的返回的地址。

(2)    Jcc (eflags)标志寄存器决定程序的去向。


图1

Cf 进位标志 —— 如果运算结果产生了一个进位或者错位,那么值为1,否则为0

Pf 奇偶标志 —— 反应运算结果中1的个数的奇偶性 0表示为奇数 1表示为偶数

Af  辅助进位标志 —— 在字操作是发生地位字节向高位字节进位或者错位的时候气质位1,在字节的操作时候发生低四位向高四位的进位或错位的时候其值为1

Zf 零标志 ——用来反映运算结果是否为零如果其值为0 为1

Sf 符号标志 ——用来反映运算结果的符号位,它与运算结果的最高位相同

Of 溢出标志 ——用于反映有符号数的加减乘除运算的结果是否溢出,如果运输案的结果超出了当前运算的为数的范围那么称之为溢出则Of的值表示为 1


图 2

**************************************************************************************

计算机的加法运算其实就是做位的运算。 计算机的减法的计算过程也可以是做特殊的加法运算。乘法是多个相加,循环多个加法运算就是做乘法运算,除法运算其实就是做乘法运算,判断多少次该运算可以得到这个数字,就是做除法运算的本质。

例如做减法运算4-5=?即 4+(-5)

1. 异或 OX

0000 0100

1111 1011

-------------  异或 OX

1111 1111

2. 判断有没有进位

0000 0100

1111 1011

------------- 若计算结果没有进位,则上面的计算结果就是运算结果值(00000000)

0000 0000


寄存器

寄存器32位EAX、16 位AX 、8位 AL,其中:

4 个数据寄存器(EAX、EBX、ECX、EDX),即 通用寄存器

2 个变址和指针寄存器(ESI、EDI) 

2 个指针寄存器(ESP、EBP)

6 个段寄存器(ES、CS、SS、DS、FS、GS)

1 个指令指针寄存器(EIP) 

1 个标志寄存器(EFlags)

内存 进程的内存映射到了物理内存再映射到其他的内存设备和内存条

使用mov 指令移动数据的时候必须保持两边的数据宽度一样

1. dword表示两个字节 mov

    EAX ,Dword PTR DS:[0x 11111111]

2. Mov Dword ptrds:[地址],16进制的数据

3. mov eax ,dwordptr ds :[ Ecx +4 ]把ecx 里面的数据加4的地址下的只存到eax 里面

4. reg +reg*{1 , 2 ,4 ,8}

5. reg +reg*{1 , 2 ,4 ,8}+立即数

大端存储数据高位在低位,数据的低位在高位,小端存储,数据地位在低位,数据高位在高位。

内存 db 查看一个字节的数据, dw 查看两个字节的数据, dd 查看四个字节的数据。

数据的地址在内存里的地址连续的

ADD指令加法的指令

SUB 减法的指令

And 与运算的指令

or 或的运算的指令

XOR异或运算的指令

NOT非的操作的指令

MOVS指令从内存到内存之间的移动movs byte ptr es:[edi],byte ptr ds:[esi]

EFL标志寄存器 dc(10) 位表示方向为 0 为增加 1为减小

STOS将AL/AX/EAX的值存储到EDI指定的内存单元。

REP指令按照计数寄存器ECX的值重复执行字符串指令。

ESP堆栈地址寄存器使用过堆栈地址需要在ESP里面记录当前使用后的地址。

PUSH指令将数据压入堆栈,然后改变ESP寄存里面的向上移动。

POP从栈顶拿出数据,存入指定的容器里容器可以是寄存器也可以是内存,然后ESP值向下移动。

EIP存的是CPU下一次执行的内存地址,JMP指令就是修改EIP寄存器的值。

CALL指令(按F7)把下一行的指令的地址压入堆栈。

RETN 指令把栈顶的值取出来放到EIP cpu寄存器里面,然后栈顶向下移动。



DTDBUG  F7单步进行、F8按函数执行、F2下断点(INT 3 当CPU遇到这个指令就停止运行)

汇编中的函数就是一些指令的集合,大多使用CALL指令来完成操作,最后使用RETN命令返回函数。EAX寄存器通

常放函数的返回结果。函数传递参数可以使用寄存器传递、堆栈传递参数,可以传递多个参数。堆栈平衡,使用完

堆栈之后需要恢复堆栈以前的样子,如果有传递参数,当函数执行完毕应该处理传递参数导致堆栈的变化。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,033评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,725评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,473评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,846评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,848评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,691评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,053评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,700评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,856评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,676评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,787评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,430评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,034评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,990评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,218评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,174评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,526评论 2 343

推荐阅读更多精彩内容

  • 8086汇编 本笔记是笔者观看小甲鱼老师(鱼C论坛)《零基础入门学习汇编语言》系列视频的笔记,在此感谢他和像他一样...
    Gibbs基阅读 37,109评论 8 114
  • 这学期有了汇编课,但个人感觉这部分难度还是有一些的,所以写了这篇简书当做自己对于知识的复习,同时也是希望能够再次加...
    kl_w阅读 6,592评论 0 7
  • 汇编语言百度百科词条: 机器语言 由0和1组成的机器指令. 汇编语言(assembly language) 由于机...
    Superman168阅读 1,018评论 0 3
  • OD专题 OD常用快捷键 各类调试断点 F2断点(CC断点,int3断点) 内存断点内存访问断点(对内存执行、写入...
    LazzMan阅读 1,184评论 0 0
  • 简悦直播教练恬源阅读 154评论 0 1