整数算术运算中的错误

2024-09-04 04:44
文章标签 运算 错误 整数 算术

本文主要是介绍整数算术运算中的错误,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 如果一个整数被零除,将不会产生正确的结果,而是出现一个异常( exception ).在Java中,异常是标志错误的一种方法,我们将在第7章中详细地介绍。对变量或表达式应用%运算符,如果右侧的操作数是零,也将导致一个异常。

    注意,如果一个整型表达式产生的值超出了结果类型的取值范围,这个结果就会按照该数据类型的存储位数截断,结果是不正确的,而且不会得到任何提示。这样处理可以确保在程序中应用的整数类型永远能够适应由计算产生的任何结果。在有些情况下,问题可能出现在中间,即使一个表达式的最终结果在合法的取值范围内,而中间的计算超出了这个范围,也会产生截断,从而得到一个错误的结果。这里举一个常见的例子,如果你使用整型,用2000000乘以100000再除以500000,若先执行乘法运算,就不会获得正确的结果,这是因为乘法的结果超出了整型所能表示的最大值。显然,要是事先知道会发生这类问题,使用一个括号,使除法先被执行,就可以防止它的发生。但是,你要记住,整数除法产生的是一个整数结果,所以,不同的执行顺序可能会产生不同的结果。

    浮点运算

    这四种基本的算术运算符+、一、*、/同样可以应用在浮点表达式中。我们可以在另一个版本的Fruit程序中进行一些试验,这个版本我们称作AverageFruit(平分水果).试试看-个平分水果

    将Fruit.java文件按照下列程序进行修改,并另存为AverageFruit.java.如果愿意的话,你可以将前面使用的新增的代码添加到程序中,是程序在结束前等待键入Enter键。

    piblic calss AverageFruitpublic static main(string[] args)
    {
    //Delare and initialize three varlables
    double numOrange=50.OE-1;
    double numApples=1.0E1;
    double averageFruit=0.0
    averageFruit=InumOranges+numApples)/2.0
    system.out.println(Atotally fruity program)
    system.out.println(Average Fruit in +averageFruit)
    }
    }

    这段代码将产生输出结果:
    A totally fruity propram
    Average fruit is 7.5

    该程序用水果的总数除以2.0来计算它的平均数。正像你所看到的,我们在程序中使用各种形式对double型变量进行初始化,把5.0写成这种形式并不是很好的方法,它只说明你可以书写一个负数指数的数值。

其他的浮点型运算符

    你可以对浮点型变量应用++或一一运算符,其效果与整数变量一样,以1.0的幅度递增或递减浮点型变量。你可以使用前缀或后缀格式,并且每种格式的操作与整数变量完全相同。我们也可以对浮点型数值应用取模运算符%.对于如下操作;
    floatoperandl%floatperand2

    其结果为floatperand1除以floatOperand2得到一个整倍数之后的浮点型余数。例如,

    表达式12.6%5.1结果为2.4

    浮点型算术运算中的错误状态

    浮点型算术运算有可能产生两种错误状态:一种是计算结果超出了取值范围:另一种是结果的数值在数学上是不确定的,比如,0除以0

    为了说明第一种错误,我们可以用一个变t记载水果(fruit)的种类数目,可以定义为:
    double fruitTypes=2.0

    然后再重新编写计算式:
    averageFruit*(numoranges+numApples)/fruitTypes;

    这样更改对其本身来说并没有什么特别的意义,但是当fruitypes为0.0时,这个程序的输出结果将是:
    A toxally fruity program
    Average  fruit is Tnfini.ty

    Infinity表示正无穷大,即大于dOUble类型所能表示的最大数值。负无穷大将输出-Infinity.实际上,你并不希望被零除,任何计算结果只要超出double类型所能表示的最大数值,就会产生这样的结果。例如。用一个非常小的数值重复进行除运算,例如,1.OE-300就会产生一个超出范围的结果。

    如果你想看看不确定数值的样子,就可以用下面这条语句替代计算averageFruat的语句:
    averageFruit={numOranges-5.0)/(numApples-10.0);

    这条语句没有什么实际意义,但它可以产生一个不确定的数值。averageFruit将输出结果NaN.这个值被称为Not-a-Number(非数字),表示不确定的数值。

    一个被赋予不确定值的变量将中断任何使用它的表达式,并且产生结果:N当用一个有穷数值与一个正无穷或负无穷数值进行加、减或乘运算时,结果还是正无穷或负无穷,但是如果你用任何有穷数值除以正无穷或负无穷数值时其结果为0.

这篇关于整数算术运算中的错误的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1135034

相关文章

SpringBoot全局异常拦截与自定义错误页面实现过程解读

《SpringBoot全局异常拦截与自定义错误页面实现过程解读》本文介绍了SpringBoot中全局异常拦截与自定义错误页面的实现方法,包括异常的分类、SpringBoot默认异常处理机制、全局异常拦... 目录一、引言二、Spring Boot异常处理基础2.1 异常的分类2.2 Spring Boot默

JAVA Calendar设置上个月时,日期不存在或错误提示问题及解决

《JAVACalendar设置上个月时,日期不存在或错误提示问题及解决》在使用Java的Calendar类设置上个月的日期时,如果遇到不存在的日期(如4月31日),默认会自动调整到下个月的相应日期(... 目录Java Calendar设置上个月时,日期不存在或错误提示java进行日期计算时如果出现不存在的

Nginx错误拦截转发 error_page的问题解决

《Nginx错误拦截转发error_page的问题解决》Nginx通过配置错误页面和请求处理机制,可以在请求失败时展示自定义错误页面,提升用户体验,下面就来介绍一下Nginx错误拦截转发error_... 目录1. 准备自定义错误页面2. 配置 Nginx 错误页面基础配置示例:3. 关键配置说明4. 生效

SpringBoot项目整合Netty启动失败的常见错误总结

《SpringBoot项目整合Netty启动失败的常见错误总结》本文总结了SpringBoot集成Netty时常见的8类问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、端口冲突问题1. Tomcat与Netty端口冲突二、主线程被阻塞问题1. Netty启动阻

SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)

《SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)》本文总结了SpringBoot项目整合Kafka启动失败的常见错误,包括Kafka服务器连接问题、序列化配置错误、依赖配置问题、... 目录一、Kafka服务器连接问题1. Kafka服务器无法连接2. 开发环境与生产环境网络不通二、序

解决java.util.RandomAccessSubList cannot be cast to java.util.ArrayList错误的问题

《解决java.util.RandomAccessSubListcannotbecasttojava.util.ArrayList错误的问题》当你尝试将RandomAccessSubList... 目录Java.util.RandomAccessSubList cannot be cast to java.

Java编译错误java.lang.NoSuchFieldError的解决方案详析

《Java编译错误java.lang.NoSuchFieldError的解决方案详析》java.lang.NoSuchFieldError是Java中的一种运行时错误,:本文主要介绍Java编译错... 目录前言解决方案1. 统一JDK版本环境2. 优化maven-compiler-plugin配置3. 清

Navicat连接Mysql8.0.11出现1251错误的解决方案

《Navicat连接Mysql8.0.11出现1251错误的解决方案》在重装电脑并安装最新版MySQL后,Navicat和Sqlyog连接MySQL时遇到的1251和2058错误,通过将MySQL用户... 目录Navicat连接mysql8.0.11出现1251错误原因分析解决问题方法有两种总结Navic

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转