汇编学习笔记二

指令的执行

指令的长度是可以是多个字节

  • cpu从cs:ip所指向的内存单元中读取指令,存放到指令缓存器中
  • ip=ip+所读指令的长度,从而指向下一条指令
  • 执行指令缓存器的内容,回到下一个步骤

这个顺序是很重要的,为什么要使用2和3的顺序哪,这是因为当我们调用一个函数时使用这种方式很好用

我们可以得出结论,数据和指令是没有差别的,当使用读取cs:ip指向的地址,cpu便将其当成指令执行

debug使用
-u 表示显示出当前位置的代码
-u 段地址:偏移地址 显示指定位置的代码
-d 表示显示当前位置的数据
-u 段地址:偏移地址 显示指定位置的数据
-a 表示直接在当前位置写入指令
-a 段地址:偏移地址 表示在指定的位置写入指令
-r 表示显示当前寄存器的内容
-r 寄存器 然后显示指定寄存器的内容在下一行写入 :2000表示将这个寄存器的内容设置成2000
-e 段地址:偏移地址 可以改写内存的内容

jmp指令

jmp是转移指令是jump的简写,表示跳跃的意思。
指令的格式: jmp 2000:0表示将cs设置成2000,将ip设置成0,因此这个指令能够改变指令执行的位置

cs和ip寄存器是不能够使用mov来进行更改的,只能使用jmp来改变
比如 mov cs,1000是错误的
还可以使用
jmp 寄存器
的方式来更改ip的内容

call 函数名 表示函数的开始
这个指令也是一个转移指令,但是这个指令和jmp还是有区别的,因为call指令会保存一个当前的执行到的位置保存在内存中。

ret 这个指令是在函数的结束的一个指令,他的操作是将call指令执行时保存的那个地址还原回来。

上面两个的作用实现了函数的调用

我们可以使用

-e 2000:0
输入数据

-r cs
:2000
-r ip
:0
表示改变cs:ip
现在我们便可以执行了

问题:
call指令将ip这个偏移地址值存放到那里去了 ret可以拿回

小端法 表示高位在高地址 低位在低地址

ds段地址寄存器

mov al,ds:[0]
mov al,ds:[1]

mov ax,ds:[0]
mov ax,ds:[1]

mov ds:[0],ax
mov ds:[1],ax

mov ds:[0],al
mov ds:[1],al

mov ax,[1]

字节型数据和自行数据在内存中的存放
使用小端法进行存放
ds段地址寄存器 数据段寄存器
cs和指令有关

栈 是一段连续的存储单元

入栈和出栈的数据长度都是16位的,因此push和pop的对象都是16位的

栈顶标记 在入栈时决定了押入栈的数据

栈顶标记是内存地址 内存地址是使用段地址和偏移地址表示的
在8086cpu中 将段地址寄存器ss和偏移地址寄存器sp所组合的内存地址当成栈顶标记

因此ss和sp只能确定一个地址 栈顶地址

push的工作原理表示将数据入栈,然后sp=sp-2

pop的工作原理表示将数据出栈,然后sp=sp+2

使用 d ss:偏移地址可以显示栈的数据

在入栈时会将寄存器的值放入栈中

我们可以控制栈的位置和大小

比如我们更改ss的值来设置栈的位置 设置sp的大小来决定栈的大小,这样便可以在sp处入栈,直到ss*10h处

所以说我们可以随便设置一个栈的地址

栈顶的越界问题
当数据的存储满时,还继续push变会栈的越界,会破坏其他的数据

pop和push只影响sp的值
sp的变化的范围 0~ffffH
因此栈的大小是有范围的 如果超过这个返回会覆盖栈的内容,因为ss是不变的,sp会变,sp从某个值一直减小到0,然后又从ffffH继续减小,会覆盖原来存入栈的内容

如果我们需要使用函数需要设置ss和sp来设置一个栈,然后使用call指令,这个call指令有两个作用,一个是保存当前的ip值到栈的最高位置中,另一个是设置ip的新值来获取函数的执行地址。

栈的作用便是临时性保存数据,这是因为寄存器是很少的,当执行另外一个功能时,我们需要临时保存数据到内存中,否则当其他代码使用寄存器时会覆盖掉寄存器的内容。

栈的作用

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

推荐阅读更多精彩内容

  • 王爽汇编全书知识点大纲 第一章 基础知识 机器语言 汇编语言的产生 汇编语言的组成 存储器 cpu对存储器的读写 ...
    2c3ba901516f阅读 2,405评论 0 1
  • 计算机通过执行指令序列来使机器得以工作,所以对于每一系列的计算机都有指定的一组指令集供计算机使用,这组指令...
    未来科技工作室阅读 7,862评论 1 10
  • 汇编总结 汇编的发展史 机械语言 由0和1组成的机器指令(如:0101 0001 1101 0110) 汇编语言(...
    iChuck阅读 1,299评论 1 8
  • 静谧的夜, 月光幽幽, 天空中有几点星星忽明忽暗, 没有白天的嘈杂, 一切都回归了一样, 一种祥和的感觉。 我的心...
    可心可可阅读 75评论 0 2
  • 青春诗之丽江的鱼 丽江的雪,以另一种方式穿城而过 就像穿城而过的烈酒和爵士舞 以及四方街上震耳欲聋的月光 青春总是...
    巴特尔邱阅读 159评论 0 1