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

关于浮点数据的算术运算

 
阅读更多
先看一下程序:
public class Test{
	public static void main(String args[]){
		System.out.println(4.0f - 2.9f); 
		System.out.println(1234f/0);
		System.out.println(-5678f/0);
		System.out.println(1234f%0);
		System.out.println(-5678f%0);
		System.out.println(0.0/0);
		System.out.println(0.0%0);
	}
}

运行结果如下:
1.0999999
Infinity
-Infinity
NaN
NaN
NaN
NaN
为什么会出现这样的结果呢?
4.0f - 2.9f 不是等于1.1吗?除法运算与取余运算除以0时不是会出现异常吗?
原因如下:
(1)浮点运算的结果会与实际的数值有一定的误差。因为浮点数据在进行运算时,计算机算出的是小数点后的n位,与实际的数值会有一定的误会,它只能尽量的接近实际值。
float型数据4.0减去浮点数据2.9的结果,数学计算结果是1.1,但计算机计算出的结果只能尽量地去接近1.1。
(2)在浮点数据的算术运算时,如果进行一个浮点型数据/0或%0的运算时,运行时并不会出错。因为:在Java语言中定义了三个特殊的浮点值来表示浮点数/0或%0的运算时的各种出错情形:
☆ Infinity:正无穷大    (正浮点数/0)
☆ –Infinity:负无穷大   (负浮点数/0)
☆ NaN:Not a Number   (0.0/0或0.0%或正负浮点数%0或负数开平方根)
分享到:
评论

相关推荐

    DSP实验二 基本算术运算

    在数字信号处理(DSP)领域,基本算术运算扮演着至关重要的角色,因为它们是所有复杂算法的基础。本文将深入探讨在CCS2000(Code Composer Studio)环境下进行这些基本运算的方法,并通过实际的实验报告和代码来增强...

    计算机算术运算实现原理全解.rar

    本pdf文档介绍了计算机算术运算的原理、结构与设计。从简单的各类加减法到各种算法实现的乘法器、除法器,以及一些浮点运算、函数运算等等。深入浅出的解扰各种实现方法,帮你快速入门。作为手头一个全面的查找手册...

    算术运算类指令.docx

    第13讲的内容虽然没有给出具体细节,但从上下文可以推测,可能涵盖了更高级的算术运算指令,或者是对前面讨论的算术运算类指令的扩展应用,如乘法、除法指令,或者与浮点运算相关的指令,这些指令在处理复杂数学问题...

    易语言核心支持库汇编版算术运算

    因此,将算术运算实现为汇编版本,能够使易语言处理数据时达到更高的性能。 算术运算在计算机科学中是最基本的操作,包括加法、减法、乘法、除法以及各种高级运算,如指数、对数、平方根等。在易语言中,这些运算被...

    半精度浮点格式数据运算程序

    1. **利用位操作**:在C语言中,位操作通常比其他算术运算更快,因此在处理指数和尾数时可以尽量使用位运算。 2. **减少浮点转换次数**:频繁的浮点转换可能会增加计算开销,尽可能在半精度范围内完成计算。 3. **...

    有关算术运算,变量,数组操作等的C#实例源码

    在C#编程语言中,算术运算、变量和数组操作是基础且至关重要的概念,对于任何初学者或经验丰富的开发者来说,理解并熟练掌握这些概念是编写高效代码的关键。以下是对这些主题的详细阐述: 一、算术运算 C#支持多种...

    C高级语言程序设计:03算术运算与逻辑运算.pptx

    ### C高级语言程序设计:算术运算与逻辑运算 #### 运算符概述 C语言提供了多种运算符来处理各种计算需求,主要包括算术运算符、关系运算符、逻辑运算符、位运算符、赋值运算符、条件运算符、逗号运算符、指针运算符...

    Vivado—加减乘除算术运算仿真

    本教程将聚焦于Vivado中的加减乘除算术运算仿真,这对于理解和实现数字电路系统至关重要。 首先,我们需要了解Vivado的工作流程。它通常包括以下几个步骤: 1. **项目创建**:在Vivado环境中,首先需要创建一个新...

    DSP中浮点转定点运算--举例及编程中的心得

    【浮点转定点运算在DSP中的应用】 ...总结来说,浮点转定点运算在DSP编程中是一个重要的环节,涉及到数据格式的转换、精度控制和硬件优化等多个方面。通过具体实例和编程经验分享,可以更好地理解和实践这一过程。

    3-05 算术运算类指令.zip

    标题"3-05 算术运算类指令.zip"暗示了这是一个关于这个主题的资料集合,可能包含详细的讲解和实例。 算术运算类指令主要包括加法、减法、乘法、除法以及各种提升的算术运算,如取模、平方根等。这些指令直接在CPU...

    设计算术单元最重要的是什么?当然是理解浮点运算.rar

    几乎每种语言都有浮点数据类型;从 PC 到超级计算机都有浮点加速器;多数编译器可随时进行编译浮点算法;而且实际上,每种操作系统都必须对浮点异常 (如溢出)作出响应。本文将为您提供一个教程,涉及的方面包含对...

    易语言核心支持库汇编版算术运算源码.7z

    1. **数据类型与运算符**:易语言中的算术运算涉及到多种数据类型,如整型、浮点型等。在汇编层面,这需要考虑不同类型的数据在内存中的表示和转换,以及对应的运算指令。例如,对于整数运算,可能使用ADD(加法)、...

    模拟CPU算术运算的C语言代码

    在本文中,我们将深入探讨如何使用C语言通过位操作来模拟CPU的算术运算过程。这一技术对于理解计算机底层工作原理、优化代码性能以及在没有现成库函数可用时实现自定义运算非常有用。 首先,我们要知道CPU进行算术...

    C#编程.NET框架的算术运算

    在C#中,算术运算是一项基本操作,它涵盖了加法、减法、乘法、除法以及整数和浮点数的提升。本文将深入探讨C#中的算术运算及其在.NET框架中的实现。 首先,我们有基本的算术运算符,包括: 1. 加法(+):用于将两...

    基于FPGA双精度浮点加减运算的验证.pdf

    首先,双精度浮点数表示标准是IEEE754标准,该标准为二进制浮点数的算术运算定义了格式和规则。在IEEE754标准中,双精度浮点数占用64位:1位符号位、11位阶码(用移码表示)、52位尾数(用原码表示)。双精度浮点数...

    浮点运算器 Verilog

    在Verilog中实现这样的浮点运算器,涉及到硬件描述语言的基础知识、浮点数表示法、算术逻辑单元(ALU)设计、以及测试激励的编写。 首先,浮点数在计算机中通常遵循国际标准如IEEE 754,该标准定义了浮点数的二进制...

    浮点运算[参照].pdf

    浮点运算是一个复杂的过程,涉及到数值表示、算术运算、规格化、舍入和溢出检查等多个环节。对于软件开发者而言,掌握这些细节是编写高效且精确数值计算代码的基础。在高性能计算和数值稳定性要求较高的环境下,对...

    计算机组成原理实验----8位算术逻辑运算ALU

    还有半溢出或借位标志,它们对于处理复杂算术运算(如乘法和除法)的中间步骤非常有用。 在实际的实验中,可能需要设计和搭建一个8位ALU的电路模型,这可能涉及使用逻辑门(如AND、OR、NOT和XOR门)以及触发器等...

    基于vhdl的浮点运算硬件实现

    vhdl实现浮点运算,极大地扩展了FPGA的运算方位,使得fpga可以同时进行逻辑运算和浮点算术运算

    vb.net初学者系列【算术运算符号】

    ### VB.NET初学者系列——算术运算符号 在学习任何编程语言时,理解其基本的算术运算符号是非常重要的一步。对于VB.NET这样的语言来说,掌握这些基础操作可以帮助开发者更高效地编写代码,并且能够更好地理解和调试...

Global site tag (gtag.js) - Google Analytics