首页 > 汇编语言 > 浮点数处理与指令编码
阅读:93
汇编语言混合模式运算简述
都目前为止,算术运算只涉及实数。应用程序通常执行的是包含了整数与实数的混合模式运算。整数运算指令,如 ADD 和 MUL,不能操作实数,因此只能选择用浮点指令。Intel指令集提供指令将整数转换为实数,并将数值加载到浮点堆栈。
【示例 1】下面的 C++ 代码将一个整数与一个双精度数相加,并把和数保存为双精度数。C++ 在执行加法前,把整数自动转换为实数:
【示例 1】下面的 C++ 代码将一个整数与一个双精度数相加,并把和数保存为双精度数。C++ 在执行加法前,把整数自动转换为实数:
int N = 20;
double X = 3.5;
double Z = N + X;
.data
N SDWORD 20
X REAL8 3.5
Z REAL8 ?
.code
fild n ;整数加载到ST(0)
fadd X ;将内存操作数与ST(0)相加
fstp z ;将ST(0)保存到内存操作数
int N = 20;
double X = 3.5;
int Z = (int)(N + X);
fild N ;整数加载到ST(0)
fadd X ;将内存操作数与ST(0)相加
fist Z ;将ST(0)保存为整型内存操作数
修改舍入模式
FPU 控制字的 RC 字段指定使用的舍入类型。可以先用 FSTCW 把控制字保存为一个变量,再修改 RC 字段(位 10 和 11),最后用 FLDCW 指令把这个变量加载回控制字:
fstew ctrlWord ;保存控制字
or ctrlWord, 110000000000b ;设置眈=截断
fldcw ctrlWord ;加载控制字
fild N ;整数加载到ST(0)
fadd X ;将内存整数与ST(0)相加
fist Z ;将ST(0)保存为整型内存操作数
fstcw ctrlWord ;保存控制字
and ctrlWord, 001111111111b ;重置舍入模式为默认
fldcw ctrlWord ;加载控制字
所有教程
- socket
- Python基础教程
- C#教程
- MySQL函数
- MySQL
- C语言入门
- C语言专题
- C语言编译器
- C语言编程实例
- GCC编译器
- 数据结构
- C语言项目案例
- C++教程
- OpenCV
- Qt教程
- Unity 3D教程
- UE4
- STL
- Redis
- Android教程
- JavaScript
- PHP
- Mybatis
- Spring Cloud
- Maven
- vi命令
- Spring Boot
- Spring MVC
- Hibernate
- Linux
- Linux命令
- Shell脚本
- Java教程
- 设计模式
- Spring
- Servlet
- Struts2
- Java Swing
- JSP教程
- CSS教程
- TensorFlow
- 区块链
- Go语言教程
- Docker
- 编程笔记
- 资源下载
- 关于我们
- 汇编语言
- 大数据
- 云计算
- VIP视频