linux阶乘,Linux下汇编语言------计算n的阶乘

用高级语言比方C语言写个阶乘非常easy,那如今就来熟悉下Linux使用AT&T汇编格式写一个程序来计算阶乘吧

写法一是 使用跳转指令实现。写法二是使用函数来实现

约定:本程序没有将结果打印在标准输出上。

须要使用GDB调试查看

写法一

#as filename.s -o filename.o

#ld filename.o -o filename

# gdb filename

.section .data

.section .text

.globl _start

_start:

movl $1, %eax #result = 1

movl $6, %ecx # n = 5

cmpl $1, %ecx

jle .loop_exit

.start_loop:

imull %ecx, %eax

subl $1, %ecx

cmpl $1, %ecx

jge .start_loop

movl %eax, %ebx

movl $1, %eax

int $0x80

.loop_exit:

movl $1, %eax

int $0x80--------------------函数写法待更新-------------------------

写法二:函数递归

.section .data

.section .text

.globl _start

_start:

pushl $5

call .JC

movl %eax, %ebx

movl $1, %eax

int $0x80

.JC:

pushl %ebp

movl %esp, %ebp

pushl %ebx

subl $4, %esp

movl 8(%ebp), %ebx #get n = 5;

movl $1, %eax #result = 1;

cmpl $1, %ebx

jle .L1

leal -1(%ebx), %eax

movl %eax, (%esp)

call .JC

imull %ebx, %eax

.L1:

addl $4, %esp

popl %ebx

popl %ebp

ret

查看结果:echo $?

当然使用gdb来查看,会更明确。

使用 echo $? 来查看的话,貌似n超过6了结果就显示不对,所以还是用gdb保险

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用RISC-V汇编语言实现阶乘的代码: ``` # 计算 n 的阶乘 # risc-v汇编语言 .data n: .word 5 # n 的值为 5 .text .globl main main: lw a0, n # 将 n 的值加载到寄存器 a0 中 li a1, 1 # 将 1 加载到寄存器 a1 中,作为初始值 jal factorial # 跳转到 factorial 函数 # 此时,a0 中存储的是 n 的阶乘的值 # 可以将其存储到其他寄存器或内存中使用 factorial: # 函数开始,将参数保存到栈中 addi sp, sp, -8 # 分配 8 字节的栈空间 sw ra, 4(sp) # 保存返回地址 sw a0, 0(sp) # 保存 n 的值 # 检查 n 的值是否为 0 或 1,如果是则直接返回 1 lw a0, 0(sp) # 将 n 的值加载到寄存器 a0 中 li a1, 1 beq a0, a1, return # 如果 n == 1,直接返回 1 li a1, 2 beq a0, a1, return # 如果 n == 2,直接返回 2 # 如果 n > 2,则进行递归计算 lw a0, 0(sp) # 将 n 的值加载到寄存器 a0 中 addi a1, a0, -1 # 计算 n - 1 的值 jal factorial # 递归调用 factorial 函数 lw a0, 0(sp) # 将 n 的值加载到寄存器 a0 中 mul a0, a0, x10 # 计算 n * (n - 1) 的值 # x10 表示函数返回值,可以将结果保存到其中 # 也可以将结果保存到其他寄存器或内存中 # 函数结束,将结果返回 return: lw a0, 0(sp) # 将 n 的值加载到寄存器 a0 中 lw ra, 4(sp) # 将返回地址加载到寄存器 ra 中 addi sp, sp, 8 # 释放栈空间 jr ra # 返回到调用函数的地址 ``` 在该代码中,使用了递归的方式计算阶乘。在 `factorial` 函数中,首先将参数 `n` 的值保存到栈中,然后判断 `n` 是否为 0 或 1,如果是,则直接返回 1。如果 `n` 大于 1,则递归调用 `factorial` 函数计算 `n - 1` 的阶乘,并将结果乘以 `n` 得到 `n!` 的值。最后,将结果返回到调用函数的地址。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值