定点数与浮点数

如何解决定点数与浮点数

| 定点和浮点数的计算机体系结构有哪些优点/缺点?我可以理解,两者都会导致某种程度的错误。 我的其他问题是 这些错误是如何产生的? 一种形式比另一种更好吗?     

解决方法

从浮点指南:   为什么需要浮点数      由于计算机内存有限,因此您   无法存储无穷大的数字   精确度,无论您是否使用   二进制分数或十进制小数:at   有些时候你必须切断。但   需要多少精度?在哪里   需要吗?多少个整数   多少个小数位?         给建筑工程师   高速公路,是否重要   它的宽度是10米或10.0001米-首先,他的测量结果可能不那么准确。   对于设计微芯片的人来说   0.0001米(十分之一毫米)是巨大的差异-但是   他将永远不必面对   距离大于0.1米。   物理学家需要利用速度   光(约3亿)和牛顿   重力常数(约   0.0000000000667)在同一计算中。         满足工程师和芯片   设计师,数字格式必须   提供非常准确的数字   不同的幅度。但是,只有   需要相对精度。至   满足物理学家的要求   可能进行计算   涉及不同的数字   数量级。      基本上,   整数和小数位数不是   有用-解决方案是一种格式   一个浮点数。 至于您的其他问题: 所有不准确的产生都是由于一个原因:您正试图将无限量的数据(例如所有有理数)放入有限的空间(例如64位)中。格式之间唯一不同的是如何准确地表示可以分配的数字。 浮点格式更好,句号。尽管缺少定点共振峰,但它们仍然没有很多限制(几乎所有定点格式也都有)。 话虽这么说,浮点数与定点数的问题常常与二进制数与十进制数混淆了-特别是,人们经常将二进制浮点数格式与(隐式)十进制定点数格式进行比较。无法准确地表示小数部分令大多数人感到惊讶,因此他们认为“浮点格式”有很大的缺点,而实际上却是二进制格式的缺点,一点也不让人惊讶无法准确表示1/3之类的数字。     ,您尚未指定使用哪种编程语言,但是,大多数编程语言没有内置的定点类型。 像C和C ++这样的主流语言具有整数类型和浮点类型。如果您打算使用带有四个小数的定点类型之类的东西,则必须在现有的整数类型之上实现。或者,使用现有的库。 当谈到更好的问题时,答案是“取决于”。您需要考虑的事情是: 您打算使用哪种硬件?大多数现代主机(PC :)都有专用的浮点硬件,例如高端嵌入式系统。但是,当使用低端嵌入式系统时,它不会这样做,因此它必须根据现有的汇编程序指令来实现浮点运算。 您的应用程序的性质是什么?它可以自然地与四个小数一起使用吗?如果在最低有效位等上出现舍入错误,将会发生什么。     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?