16位汇编第一讲简介

                 汇编第一讲 汇编简介

一.什么是汇编

  汇编语言他是计算机语言,计算机语言通俗点说就是人类和计算机(也就是CPU)沟通的桥梁,计算机不认识人类的语言,只认得二进制(0和1)但是我们想让你算计完成我们的工作,每次都是0,和1,那样会崩溃的,(老一辈的是这样的)所以后面汇编语言出现了,用一些简单的助记符来替代机器语言(二进制)通用的语言,比如 + - * / 这种助记符,

add....汇编语言是和机器语言一一对应的.

二.汇编语言有什么用处好处

    1.学好汇编了,你可以理解计算机更为透彻

    2.学好汇编,可以增加自己的调试能力

    3.学好汇编,你可以反汇编,做一些反病毒,等等一系列的工作.

三丶语言发展史

机器语言 ->汇编语言 -> C语言 -> C++语言等等

四丶汇编语言主要操作什么

汇编语言主要操作的是寄存器

在CPU中,有八个通用寄存器

ax (add,代表相加,累加的意思)累加寄存器

bx (base,代表基地址,存放地址的寄存器) 基址寄存器

cx (count,个数,代表统计的意思)计数寄存器

dx (data,数据) 数据寄存器

SI (source) 源寄存器,存放源地址的内容的寄存器

DI (Dest) 目标寄存器,从源寄存器中memcpy到目标寄存器中

BP (base Point) 堆栈,理解为栈底指针,每次在栈中移动数据,出栈进栈,都会更新.记录的是当前的栈底

SP () 堆栈栈顶指针.

指令寄存器,以及四个段寄存器

指令寄存器,标志寄存器,以及四个段寄存器.

 IP ,和段寄存器CS一起使用,记录的是偏移(至于怎么使用,会在下一讲讲清楚) 指明了CPU要执行的那条指令

IP是和CS一起使用,用来确定销一条指令的物理地址

Flag 标志寄存器, 存放各种标志的.

五丶WindowsXp下的简单Debug调试工具的简单使用

 我们编写汇编程序,一般用debug

使用方法,

1. win + R 打开运行窗口输入cmd,在cmd中输入Debug命令

2. 直接开始菜单中 选择右边的运行窗口,输入cmd,然后在cmd输入debug命令

一丶debug中常见的指令

 a 汇编,代表我们可以开始汇编了. (把汇编代码转换为机器码)

 u 反汇编,(把机器代码变为汇编代码)

  如果你有一个写到文件的机器码文件,可以当做debug的参数传入,然后u,就可以显示文件中汇编代码了,把机器代码反汇编成了汇编代码了

t 单步不如(在vc++6.0中,相当于F11键)

r 寄存器 (相当于vc++6.0中的F10键,)可以修改寄存器的内容,比如 r cx 然后回车,输入值,然后输入p往下执行即可查看.

g 断点执行(也就是vc中的F5执行)

D 部分数据显示 (可以显示一段内存中的数据)

n 文件名 (本地创建一个文件, 例如n hello ,不用加双引号包裹)

e 指定地址写入,可以指定地址写入一段数据

w 把汇编代码写入到文件(文件是由n指令创建的)

 等等这些是常用的,具体的debug指令会放到云盘中大家下载:

 链接:http://pan.baidu.com/s/1kVDWzHl 密码:adew

 二丶使用debug截图分享

1.运行CMD,输入debug命令

2.输入a,开始汇编

mov ax,1 的意思是把 1赋值给ax

ret 的指令就是(return 返回的意思)你写的汇编程序也要返回否则就出错

3.输入p指令调试查看一下

4.利用r指令,修改寄存器的值,写入到文件,注意写入到文件必须写入字节大小,字节大大小就是cx寄存器中存储(cx 计数寄存器)

5.查看是否更改,p指令查看

6.n指令,在本地目录创建一个文件

7.w指令,将我们的代码写入到文件

8.利用winhex查看本地文件

其中B8 代表指令MOV

01 00 代表16位寄存器AX里面的值

C3 代表ret返回

9.将文件,反汇编为汇编代码,当做debug的参数

 六丶使用debug调试工具(也可以调试,亦可以当做编辑器)显示helloword指令

1.如果显示helloworld,咱们需要一个指令字典,在上面的下载链接中提供了.

指令字典的看法

1.主页面

2.点击汇编语言,选择8086

3.选择下面的功能号

上面说了,ah是高把位,我们要显示字符串,需要给这个ah赋值为09 (具体系统调用(也就是API调用显示hello下一讲详细讲解))

然后dx寄存器我们需要给定一个字符串, (e 指令指定地址 e 108 "hello$" 即可)

调用的时候,用int 21 指令调用(内部会查表,具体怎么样,下一讲细讲)

 4.使用debug显示一个helloworld

第一个指令  -e 140 mov "helloworld$" 代表我们给140地址写入一个字符串, 可以用d指令查看  d 140 回车就会显示

第二个指令 a,表示我们开始汇编

按照上面的指令字典,我们知道,dx寄存器需要是字符串的首地址, 所以利用mov 指令,把140给dx了

然后因为调用函数(也就是系统调用) ah 我们需要给9,代表调用那一项

然后int 21 代表系统调用的意思,也就是说(调用函数,开始调用函数)

然后显示了

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏coding

vim实用笔记

912
来自专栏PHP技术

给PHP开发者讲讲PHP源码-第一部分

作为一个开发者,我发现在我的日常工作中越来越多地查看PHP的源码。在为了弄清楚奇怪的边界问题和为什么某些问题应该发生的却没有发生而去理解背后究竟发 生了什么事情...

35210
来自专栏数据之美

bash/shell 解析命令行参数工具:getopts/getopt

bash 脚本中,简单点的参数选项,我们可以直接用位置参数 $1 $2 这样来获取处理了,例如下面这段代码片段: optionParam=$1 baseHd...

2258
来自专栏CSDN技术头条

c++ fstream + string 处理大数据

起因 (1)之前处理文本数据时,各种清洗数据用的都是java的File,FileReader/FileWriter,BufferedReader/Buffer...

1896
来自专栏Petrichor的专栏

Python: __future__ 模块

482
来自专栏GreenLeaves

JS模块加载系统设计V1

一、require模块 +function() { var path = location.protocol + "//" + loca...

1835
来自专栏ascii0x03的安全笔记

SEED缓冲区溢出实验笔记——Return_to_libc

参考:http://www.cis.syr.edu/~wedu/seed/Labs_12.04/Software/Return_to_libc/      ht...

3086
来自专栏思考的代码世界

Python编程从入门到实践之文件和异常处理|第12天

要使用文本文件中的信息,首先需要将信息读取到内存中。为此,我们可以一次性读取文件的 全部内容,也可以以每次一行的方式逐步读取。

4167
来自专栏HTML5学堂

2015.12.23 HTML5真题练习

HTML5学堂:每天一道题,强壮程序员!今日主要涉及12.22日关于作用域、预编译执行知识的题目解答,以及一道涉及逗号运算符和for循环的题目。 HTML5真题...

2595
来自专栏杨建荣的学习笔记

shell基础学习总结(二) (r3笔记第72天)

-->关于shell编程之文件比较 可以使用如下的选项来做文件的比较。有了这些选项,文件的比较来说都是游刃有余。 -d file file是否存在...

2424

扫码关注云+社区