`
Ydoing
  • 浏览: 105986 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

汇编语言学习系列 递归实现

 
阅读更多

假如汇编语言要实现如下C语言的功能,编译环境Ubuntu14.04(32位)。

复制代码
#include<stdio.h>
int refact(int n){
    if(n == 1)
        return 1;
    else
        return n * refact(n - 1);
}

int main(){
    int a = 4;
    printf("%d\n", refact(a));
    return 0;
}
复制代码

无论对于递归实现还是循环实现,汇编都是将转换为跳转语句实现。可以把上面的代码转换为

复制代码
refact:
    if((n-1) <= 0)
    goto done;

    body-statement
        
done:
复制代码
  • 汇编代码refact.s
复制代码
.section .data
        a: .int 4
        format: .asciz "%d\n"
.section .text
.global _start
_start:
        pushl %ebp
        movl %esp, %ebp
        subl $8, %esp #allocate storage space
        
        movl a, %edx    #get a
        movl %edx, (%esp)    #save value of a on stack
        
        call refact
        
        pushl %eax
        pushl $format
        call printf
        movl $0, (%esp)
        call exit                    
        
refact:
        pushl %ebp
        movl %esp, %ebp
        pushl %ebx
        subl $4, %esp    #allocate storage space
        
        movl 8(%ebp), %ebx    #get n
        cmpl $1, %ebx    
        jle done    #test (n-1) >= 0
        
        leal -1(%ebx), %eax    #(n-1)
        movl %eax, (%esp)  #save (n-1) on the stack
        call refact
        imul %ebx, %eax  #use %eax to save result 
        
done:    
        addl $4, %esp    #release space
        popl %ebx
        popl %ebp
        ret
        
复制代码
  • 编译

as refact.s -o refact.o

  • 链接

ld -lc -I /lib/ld-linux.so.2 refact.o -orefact

  • 执行

./refact

分享到:
评论

相关推荐

    汇编语言数据统计与排序

    通过学习和实践汇编语言的数据统计与排序,不仅可以提升对底层计算机工作原理的理解,还能提高解决问题的能力。尽管高级语言已经相当普及,但掌握汇编语言仍然是计算机科学教育和系统级编程不可或缺的一部分。

    杨辉三角汇编语言的实现

    ### 杨辉三角汇编语言实现解析 #### 标题:杨辉三角汇编语言的实现 本篇文章将深入探讨如何使用汇编语言实现著名的...这种实现方式不仅展示了汇编语言的强大功能,也为学习组合数学中的基本概念提供了一个实践案例。

    福州大学汇编语言程序设计实践作业(堆排序八皇后等).zip

    福州大学的汇编语言程序设计实践作业集合,是一系列精选的编程练习,它不仅让学生们熟悉汇编语言的编程语法,更是深入培养解决算法与数据结构问题能力的重要手段。通过对多个经典的算法和数据结构的实现,学生们能够...

    汇编语言的课后练习答案

    《汇编语言的课后练习答案》是一份珍贵的学习资源,尤其对于正在学习汇编语言的学子们来说,它提供了解答清华版汇编语言教材中所有问题的详细解析。这份资料不仅涵盖基础的指令系统,还深入探讨了汇编语言的高级特性...

    微机原理与汇编语言实验

    《微机原理与汇编语言》实验课程作为计算机科学与技术专业本科生的基石,旨在深化学生对计算机硬件与软件底层交互的理解,是学习接口技术、单片机等后续课程的必备前提。该课程通过实验教学,不仅强化理论知识,更...

    《汇编语言课程设计案例精编》源代码

    《汇编语言课程设计案例精编》是一本深入探讨IBM-PC汇编语言程序设计的教材,其中包含了大量的实例和案例,旨在帮助学习者更好地理解和掌握汇编语言编程技巧。这本书的源代码提供了丰富的实践素材,是提升汇编语言...

    80x86汇编语言程序设计教程

    本书的第二部分适合已基本掌握8086/8088汇编语言的程序员,可作为学习保护方式编程技术的教材或参考书,也可作为其他人员了解高档微处理器和保护方式编程技术的参考书,还可作为程序员透彻地了解Windows程序设计技术...

    汇编语言数据结构

    ### 汇编语言数据结构知识点详解 #### 一、数组(Array) **1.1 数组简介** 数组是一种基本的数据结构,在汇编语言中...通过对这些数据结构的学习和掌握,可以更好地理解如何在汇编语言中实现高效的数据管理和处理。

    PC汇编语言 - Paul A. Carter

    本书覆盖了数制、计算机结构、汇编语言基础、基本控制结构以及高级主题如位操作等,为读者提供了全面而深入的学习材料。 #### 数制 **1.1 数制** - **1.1.1 十进制** - 基于10的计数系统,使用0至9十个数字进行...

    汇编语言四则混合运算

    该汇编语言编写的四则混合运算程序通过一系列精心设计的子程序,实现了对复杂数学表达式的解析和计算。虽然汇编语言本身较为底层且复杂,但是通过对程序结构和关键子程序的深入理解,我们不仅可以掌握其实现机制,还...

    汇编语言程序设计项目源码.zip

    这两个文件可能是一系列相关任务的一部分,比如可能是逐步增加复杂性的程序设计案例,从基础到进阶,演示了如何通过迭代或递归实现特定功能。 4. 文件名:11.asm、09.asm、12.asm、13.asm 这些文件可能对应于不同...

    Intel汇编语言程序设计第四版

    作为汇编语言学习者,了解并掌握这些知识对于理解计算机底层工作原理、优化代码性能以及进行系统级编程至关重要。 首先,本书针对Intel架构,这意味着它涵盖了x86和x64系列处理器的汇编语言。这些处理器广泛应用于...

    汇编(PC汇编语言-翻译:伍星)

    2. **控制结构**:控制结构(如循环、条件判断)在编程中非常重要,本书详细讲解了如何使用汇编语言实现这些结构。 3. **位操作**:位操作是汇编语言中的一个重要部分,包括移位操作、按位逻辑运算等,这些操作在...

    PC保护模式汇编语言

    本书旨在帮助读者深入理解计算机硬件层面的工作原理,并通过学习汇编语言提升高级语言(如C/C++)的编程能力。书中重点介绍了现代处理器(如80386及其后续版本)的**保护模式**,这是一种更安全且适合多任务操作系统...

    汇编语言教程(assembly language)

    在这一章中,作者简要介绍了汇编语言的历史背景及其在现代计算机系统中的作用,并对学习汇编语言的重要性进行了阐述。 - **第二章:汇编语言世界中的“Hello, World”** 通过一个简单的“Hello, World”程序...

    MIPS的汇编语言程序设计教程

    ### MIPS汇编语言程序设计教程知识点详述 #### 一、引言与MIPS...通过本教程的学习,学生不仅能够掌握MIPS汇编语言的基础知识,还能深入了解计算机硬件的工作原理,为进一步学习高级计算机组织课程打下坚实的基础。

    PC汇编语言

    最后,它还介绍了在汇编语言中如何处理子程序,包括间接寻址、调用约定、可重入性和递归子程序,这些都为编写高效汇编程序打下了坚实的基础。 通过学习本书,读者能够获得对计算机工作原理的深刻理解,并能够将这些...

    IIR滤波器 ccs程序,C语言和汇编

    在本压缩包中,包含的是一个使用CCS(Code Composer Studio)开发环境的C语言和汇编语言程序,用于在硬件平台上实现IIR滤波器。 CCS是由德州仪器(TI)开发的一款强大的集成开发环境,主要用于针对TI的微控制器和...

Global site tag (gtag.js) - Google Analytics