当前位置: 首页 > 编程日记 > 正文

1、Linux汇编——初识汇编

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

前序

本来想Qt能继续坚持下来,可是绕了一大圈,最终还是选择回到学期伊始的Linux汇编编程上来。鉴于图书馆只能借到这本书,虽然不厚,但是内容还是比较实用丰富,作为入门教程相当不错。以后将不断更新其阅读内容、个人感悟和相关汇编代码。一方面和大家分享,另一方面,也锻炼我写博文的能力和培养记录的良好习惯。为以后工作做铺垫。至于Qt,我想先推推——C++11正在看,所以还是希望有一个比较好的铺垫。基础夯实了,后面的路感觉会好走一些。

正文

第二章 内存详解

这里的内存就先不详细说了,可以参考其他资料。

主要说下环境:该书使用32位X86汇编,所以默认一个字=4Bytes

寻址方式

1、立即数寻址:指令中包含传输的数字,如 :movl  $1, %eax,表示将数“1”存储到寄存器eax中。

2、寄存器寻址:指令中给出要访问的寄存器号,如:movl $1, %eax,寻找的为eax寄存器

3、直接寻址: 指令中直接给出内存的段内偏移地址。如 movl $1, 2 表示将数“1”存入内存ds:2中

4、变址寻址:基址用常数表示,偏移量存储在寄存器中。同时可以固定某个整数作为比例因子(步进)。(数组的遍历)

5、间接寻址:寄存器中存储要访问的内存偏移量。

6、基址寻址:寄存器存储基址,一个常数表示偏移量。(访问结构性数据)

第三章 编写第一个程序

程序1;

#目的:退出程序,向Linux内核返回一个状态码
#输入:无
#输出:想Linux内核返回状态码,程序运行结束后,用shell命令:echo $? 查看返回的状态码
#变量:%eax 系统调用号%ebx 返回状态吗
.section .data 
.section .text
.globl _start
_start: movl $1, %eax #系统调用号movl $0, %ebx #返回操作码int 0x80        #中断调用

如上为汇编程序exit.s,编译程序:    as exit.s -o exit.o

链接程序 :   ld exit.o -o exit

运行程序:./exit

查看返回码:echo $?

知识点:

1、.section .data :“.”表示汇编程序的伪指令,指导编译器的行为。该段为数据段。

2、.section .text:该段为代码段,本段存放需要执行的命令。

3、.globl _start:表示标号_start后面的代码段为全局,其表示为程序的入口。

4、前缀“e”表示32位寄存器,前缀“r”表示64位寄存器,如“rax”

5、通用寄存器有以下几个:%eax, %ebx, %ecx ,%edx, %edi, %esi

专用寄存器有以下几个:%ebp,%esp,%eip,%eflags

6、当进行系统调用时,%eax存系统调用号,%ebx存向系统返回的状态码,int表示中断,此指令将调用终端程序。

程序2:

#目的:寻找一维数组中最大值
#变量:    %edi——当前数组元素的下表(索引)
#          %ebx——当前最大值
#          %eax——当前数据项
#数据段:data_items:0表示数组结束
.section .datadata_items: .long 3,67,32,222,45,75,54,33,22,11,66.section .text
.globl _start
_start: movl $0, %edi                     #索引值从0开始movl data_items(,%edi,4), %eax    #使用变址寻址法,给出步进长度为4movl %eax, %ebx                   #初始时第一项为最大值start_loop: cmpl $0, %eax    #判断是否到达数组末尾je loop_exit     #到达数组末尾,退出循环,作收尾工作incl %edi            #未到达末尾,索引加1movl data_items(,%edi,4), %eaxcmpl %ebx, %eax    #与当前最大值进行比较jle start_loop     # %eax <= %ebxmovl %eax, %ebx    # %eax > %ebx,则进行交换jmp start_loop
loop_exit:movl $1, %eax      # 1为系统调用exit()的调用号int $0x80          #中断调用

编译:as maximum.s -o maximum.o

链接:ld maximum.o -o maximum

运行:./maximum

查看返回结果:echo $?

知识点

1、data_items中的“.long”表示数据类型,汇编语言中有以下数据类型可供使用:

(1).byte:占1 byte, 范围0~255

(2).int  :占2 byte,范围:0~65535

(3).long :占4 byte, 范围:0~4 294 967 295

(4).ascii:用于将字符输入内存,每个字符占一个byte,如:.ascii "hello world\0",“\0”表示字符串末尾

2、对于数组,可以有如下方式表示:

(1)数组长度作为第一个元素

(2)数组末尾用特殊符号标记

3、注意上面的最大值不能超过255,因为程序的退出状态码最大为255。

4、条件跳转指令:当使用条件跳转指令时,需要使用cmpl指令对两个数进行比较:cmpl a , b。条件跳转指令有:

(1)je :当 a==b时,跳转到目标地址

(2)jg:当 b>a时,则跳转。

(3)jge:当 b >= a时,则跳转

(4)jl : 当 b <a 时,则跳转

(5)jle :当 b<=a时,则跳转

(6)jmp:无条件跳转

5、寻址方式:

(1)索引寻址方式:地址或偏移(%基址寄存器,%索引寄存器,比例因子),

结果地址=地址或偏移+%基址或偏移量寄存器+比例因子 * %索引寄存器

需要注意:地址或偏移量、比例因子必须为常数,其余两个必须为寄存器,若省略任何一项可用0代替。地址和偏移量寄存器可省略,但需加后面的“逗号”。

(2)其他寻址方式参考第二章内容

6、关于指令中数据的字长:

(1)movl表示传输一个“字”的数据,若只想传输一个“字节”,则使用指令movb,

(2)%eax的低字节为%ax,%ax的高一字节为%ah,低一字节为%al。













转载于:https://my.oschina.net/u/438386/blog/541802

相关文章:

汇编语言调用Linux系统调用

首先查找系统调用文件 #find / -name unistd.h /root/linux/include/unistd.h /usr/include/linux/unistd.h /usr/include/sys/unistd.h /usr/include/bits/unistd.h /usr/include/unistd.h 查看系统调用值 /root/linux/include/unistd.h #define __NR_setup 0 /* use…

为什么说Transformer就是图神经网络?

作者 | Chaitanya Joshi译者 | Kolen出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09;前言有些工程师朋友经常问我这样一个问题&#xff1a;“图深度学习听起来很棒&#xff0c;但是现在是否有非常成功的商业案例&#xff1f;是否已经在实际应用中部署&#xff1f;”除…

IIS日志清理CMD版,VBS版,JS版,WSH版

IIS日志清理之IIS日志生成系统(CreateIISLog.vbs) 创建文件夹Function CreateFolder(Folder)On Error Resume NextSet FSO CreateObject("Scripting.FileSystemObject")FSO.CreateFolder(Folder)If Err>0 ThenErr.ClearCreateFolder FalseElseCreateFolder Tr…

make执行过程

make 的执行过程如下&#xff1a; 1.依次读取变量“MAKEFILES”定义的 makefile 文件列表 2.读取工作目录下的 makefile文件&#xff08;根据命名的查找顺序“GNUmakefile”&#xff0c; “makefile”&#xff0c;“Makefile”&#xff0c;首先找到那个就读取那个&#xff09; …

C语言不要重复包含.h头文件和.c文件

1.不要重复包含头文件 --以上出自《C语言程序设计&#xff1a;现代方法(第2版)》 f3.h //#ifndef AE_OK #define AE_OK 0 typedef int ngx_int_t; //#endiff2.h #include "f3.h"f1.h #include "f3.h" test.c #include <stdio.h>#include &…

论推荐系统与精细化运营

作者丨gongyouliu来源 | 大数据与人工智能&#xff08;ID: ai-big-data&#xff09;随着大数据与人工智能(AI)技术的发展与成熟&#xff0c;国家政策层面对大数据与人工智能技术、创新、创业层面的支持&#xff0c;企业越来越意识到数据和AI技术的价值&#xff0c;并逐步认可数…

服务器产品选型与性价比图解

转载于:https://blog.51cto.com/lijichao/229471

解决jsp引用其他项目时出现的 cannot be resolved to a type错误

JSP页面引用其他项目的时候&#xff0c;在jsp页面上写如下代码&#xff1a; <%List<CandleEntity> candleEntities;CandleOperate candleOperate new CandleOperate(DataBaseEntity.getInstance()); %>虽然也添加了引用 <%page import"com.sjzh.xtrader.l…

ATT格式汇编语言

1.编译与链接 方法一&#xff1a;使用as #as -o test.o test.s #ld -o test test.o 方法二&#xff1a;使用gcc #gcc -o test test.s gnu连接器查找_start标签以确定程序的开始&#xff0c;但gcc查找main标签&#xff0c;所以使用gcc要把 _start改为main 2.调试 #as -gsta…

取得Repeater内部控件命令名与命令参数

前台&#xff1a; <table border"0"cellpadding"0"cellspacing"1"class"meet_tbl"><tr class"meet_title bold"><td>会议名称</td><td>制定日期</td><td>删除</td></tr…

Python在计算内存时值得注意的几个问题

作者 | 豌豆花下猫来源 | python猫&#xff08;ID:python_cat&#xff09;我之前的一篇文章&#xff0c;带大家揭晓了 Python 在给内置对象分配内存时的 5 个奇怪而有趣的小秘密。文中使用了sys.getsizeof()来计算内存&#xff0c;但是用这个方法计算时&#xff0c;可能会出现意…

HDU 1816, POJ 2723 Get Luffy Out(2-sat)

HDU 1816&#xff0c; POJ 2723 Get Luffy Out 题目链接 题意&#xff1a;N串钥匙。每串2把&#xff0c;仅仅能选一把。然后有n个大门&#xff0c;每一个门有两个锁&#xff0c;开了一个就能通过&#xff0c;问选一些钥匙&#xff0c;最多能通过多少个门 思路&#xff1a;二分通…

AI战“疫“之路:​揭秘高精准无感测温系统的全栈AI 技术

在这个全民抗疫的特殊时期&#xff0c;今年的春节返潮来得比往年迟了许多。如今不少企业结束了远程办公&#xff0c;开始陆续复工&#xff0c;一时间&#xff0c;无论是重点防控的机场、火车站&#xff0c;还是学校、企业、社区等密集型场所&#xff0c;都安排了密集的防疫驻扎…

关于text段、data段和bss段

根据APUE&#xff0c;程序分为下面的段&#xff1a;.text, data (initialized), bss, stack, heap。 data/bss/text: text段在内存中被映射为只读&#xff0c;但.data和.bss是可写的。 bss是英文Block Started by Symbol的简称&#xff0c;通常是指用来存放程序中未初始化的全局…

091023 T GIX4 项目中的 智能部署 和 智能客户端

先说一下ClickOnce的使用方法&#xff1a;先给一个要发布的工程设置安全和签名。然后发布到iis中。当用户访问该iis目录下的.application文件时,就会自动安装整个应用程序。 再说一下我们目前的应用程序。相对还是比较复杂的&#xff0c;分为框架部分和特定应用程序部分。其中的…

STL学习系列九:Map和multimap容器

1.map/multimap的简介 map是标准的关联式容器&#xff0c;一个map是一个键值对序列&#xff0c;即(key,value)对。它提供基于key的快速检索能力。map中key值是唯一的。集合中的元素按一定的顺序排列。元素插入过程是按排序规则插入&#xff0c;所以不能指定插入位置。map的具体…

人工智能改变未来教育的5大方式!

作者 | Zohaib翻译 | 天道酬勤&#xff0c;编辑 | Carol出品 | AI科技大本营&#xff08;ID&#xff1a;rgznai100&#xff09;科技正在改变着我们的生活、工作和娱乐方式&#xff0c;教育领域也不例外。 人工智能将像大多数其他领域一样全面改变教育领域&#xff0c;这取决于当…

程序在内存中运行的奥秘

简介当丰富多彩的应用程序在计算机上运行&#xff0c;为你每天的工作和生活带来便利时&#xff0c;你是否知道它们是如何在计算机中工作呢&#xff1f;本文用形象的图表与生动的解释&#xff0c;揭示了程序在计算机中运行的奥秘。 内存管理是操作系统的核心功能&#xff0c;无论…

微软虚拟化解决方案课件

微软虚拟化解决方案课件转载于:https://blog.51cto.com/yangzhiguo/231577

【Python 第8课】while

2019独角兽企业重金招聘Python工程师标准>>> 先介绍一个新东西&#xff1a;注释。python里&#xff0c;以“#”开头的文字都不会被认为是可执行的代码。 print “hello world”和 print "hello world" #输出一行字是同样的效果。但后者可以帮助开发者更…

2019年度CSDN博客之星TOP10榜单揭晓,你上榜了吗?

培根说&#xff0c;『读书造成充实的人&#xff0c;会议造成未能觉悟的人&#xff0c;写作造成正确的人』。在短信短视频快速迭代的快时代&#xff0c;更深度的思考、更正确的实践&#xff0c;更成体系的写作与分享&#xff0c;尤显可贵。这里&#xff0c;每一篇博文都是开发者…

objdump查看目标文件构成

objdump objdump是用查看目标文件或者可执行的目标文件的构成的GCC工具 反汇编 #objdump -d cpuid2 对于其中的反汇编代码 左边是机器指令的字节&#xff0c;右边是反汇编结果。显然&#xff0c;所有的符号都被替换成地址了&#xff0c; 注意没有加$的数表示内存地址&#…

jQuery--AJAX传递xml

程序代码$.ajax({ url:Accept.jsp, type:post, //数据发送方式 dataType: xml, //注意这里是xml哦 &#xff0c;不是html ( html比较简单,所以我拿xml做下例子,解释下 )data:text$("#name").val()&datenewDate(), //要传递的数据 timeout: 2000, …

ActionDescriptor 的认识

ActionDescriptor的作用是对Action方法的元数据的描述,通过ActionDescriptor我们可以获取到action方法的相关的名称,所属控制器,方法的参数列表,应用到方法上的特性以及一些筛选器;ActionDescriptor是由ControllerDescriptor类中的FindAction方法进行创建; ActionDescriptor类也…

readelf和ldd分析elf文件

1. elf 文件格式 linux系统中&#xff0c;gcc编译器编译出的object文件、可执行文件都属于elf文件。 elf文件由三个部分组成&#xff1a;elf header、program headers|section headers、sections|program segments。 如果是executable文件&#xff0c;则section部分是不需要的…

号称3个月发布最强量子计算机,卖口罩的霍尼韦尔凭什么?

作者 | Just出品 | AI科技大本营新冠疫情的发生&#xff0c;霍尼韦尔这家口罩品牌引入众人眼帘。但实际上&#xff0c;口罩业务只是这家企业的一小块副业&#xff0c;它能做的业务十分多元。3月4日&#xff0c;霍尼韦尔宣布在量子计算领域取得突破&#xff0c;将提升量子计算机…

一位老工程师前辈的忠告

诸位&#xff0c;咱当工程师也是十余年了&#xff0c;不算有出息&#xff0c;环顾四周&#xff0c;也没有看见几个有出息的&#xff01;回顾工程师生涯&#xff0c;感慨万千&#xff0c;愿意讲几句掏心窝子的话&#xff0c;也算给咱们师弟师妹们提个醒&#xff0c;希望他们比咱…

一站式学习Wireshark

https://community.emc.com/message/818739#818739 转载于:https://blog.51cto.com/jackprivate/1725190

objdump与readelf

objdump和readelf都可以用来查看二进制文件的一些内部信息. 区别在于objdump 借助BFD而更加通用一些, 可以应付不同文件格式, readelf则并不借助BFD, 而是直接读取ELF格式文件的信息, 按readelf手册页上所说, 得到的信息也略细致一些. 几个功能对比. 1. 反汇编代码 查看源代…

接口学习笔记(2009.11.24)

了解接口&#xff0c;主要是为了一道经典面试题&#xff1a;接口与抽象类的区别&#xff0c;对接口的理解却很少&#xff0c;现在学习一下。 接口只包含方法、属性、事件或索引器的签名。成员的实现是在实现接口的类或结构中完成的。 Interfacenamespace study1124{ interfa…