当前位置: 首页 > news >正文

关于浮点数的 fld、fadd、fstp 汇编指令介绍

文章目录

    • FLD
    • FADD
    • FSTP

FLD, FADDFSTP 常在一起出现,用于 float 运算。组合实现浮点数的加载、加法运算和保存

FLD

FLD 指令用于将 浮点数 从内存加载到浮点寄存器栈(FPU Stack)中。它的使用方式如下:

FLD <源内存地址>

<源内存地址> 是包含浮点数的内存地址。
FLD 指令会将该浮点数加载到 FPU Stack 的顶部。

FADD

FADD 指令用于执行两个浮点数的加法运算,并将结果存储在 FPU Stack 的顶部。它有多种使用方式,其中之一是:

FADD <目标内存地址>

<目标内存地址> 是一个包含另一个浮点数的内存地址。
FADD 指令会将 FPU Stack 顶部的浮点数与该内存地址中的浮点数相加,并将结果存储在 FPU Stack 顶部。

FSTP

FSTP 指令用于将 FPU Stack 顶部的浮点数弹出,并将其存储到指定的内存地址中。它的使用方式如下:

FSTP <目标内存地址>

<目标内存地址> 是一个内存地址,用于存储弹出的浮点数。

通过这些指令的组合,可以在 FPU Stack 中加载浮点数、执行加法运算,并将结果保存到内存中。以下是一个示例代码片段,展示了这些指令的使用:

section .datanum1 dd 3.14num2 dd 2.71result dd 0.0section .textglobal _start_start:; 将 num1 加载到 FPU StackFLD dword [num1]; 将 num2 加载到 FPU StackFLD dword [num2]; 执行加法运算FADD; 将结果保存到 result 变量FSTP dword [result]; 程序退出mov eax, 1xor ebx, ebxint 0x80

num1num2 是待加的两个浮点数,result 是保存结果的变量。

首先,FLD 指令将 num1num2 加载到 FPU Stack 中

然后 FADD 执行加法运算,最后 FSTP 将结果保存到 result 中。

http://www.lryc.cn/news/180567.html

相关文章:

  • 知识图谱小白入门(1):neo4j的安装与CQL的使用
  • 一个用java的get请求
  • 作为SiteGPT替代品,HelpLook的优势是什么?
  • uni-app:实现页面效果2(canvas绘制,根据页面宽度调整元素位置)
  • 【24种设计模式】责任链模式(Chain of Responsibility Pattern)
  • 微信小程序一对多个页面间传递数据进行通信,事件触发的实现方法
  • 软件测试之Python基础学习
  • 模块化编程+LCD1602调试工具——“51单片机”
  • 【Linux】UDP的服务端 + 客户端
  • 德国自动驾驶卡车公司【Fernride】完成1900万美元A轮融资
  • 实现水平垂直居中的十种方式
  • 头条号热点采集工具-头条号热文采集软件
  • 了解”变分下界“
  • Andriod 简单控件
  • Substructure‑aware subgraph reasoning for inductive relation prediction
  • 古诗词学习鉴赏APP设计与实现(源码+lw+部署文档+讲解等)
  • 深度学习与python theano
  • 【算法优选】双指针专题——贰
  • AI智能电话机器人实用吗
  • 网络爬虫--伪装浏览器
  • C/C++程序的内存开辟
  • 【Java 进阶篇】JDBC DriverManager 详解
  • 2023年Linux总结常用命令
  • Mybatis3详解 之 全局配置文件详解
  • 力扣-345.反转字符串中的元音字母
  • 643. 子数组最大平均数I(滑动窗口)
  • Java 21 新特性:虚拟线程(Virtual Threads)
  • 18scala笔记
  • 【LeetCode周赛】LeetCode第365场周赛
  • 响应式设计的实现方式