`
wwty
  • 浏览: 544413 次
  • 性别: Icon_minigender_1
  • 来自: 北京-郑州
社区版块
存档分类
最新评论

java当中float以及double数据类型的掌握

阅读更多

 * java当中默认声明的小数是double类型的;

 * double d=4.0

 * 如果声明:

 * float x = 4.0则会报错,需要如下写法:

 * float x = 4.0f或者float x = (float)4.0

 * 其中4.0f后面的f只是为了区别double,并不代表任何数字上的意义

 * 

 * float 内存分配4个字节,占32位,有效小数位6-7位

 * double 型 内存分配8个字节,有效小数位15位

 

flaot:

		float x = 3.56412f;
		float y = 5.13f;
		System.out.println(x+y);
 输出:8.69412

 

 *  在《Effective Java》这本书中也提到这个原则: float和double只能用来做科学计算或者是工程计算; 在商业计算中我们要用java.math.BigDecimal。

如下代码:

 

		double z = 3.564;
		double a = 5.13;
		System.out.println(z+a);

 输出:8.693999999999999

 

如果使用java.math.BigDecimal类进行计算:

   /**
    * 提供精确的加法运算。
    * @param v1 被加数
    * @param v2 加数
    * @return 两个参数的和
    */
    public static double add(double v1,double v2)
    {
        BigDecimal b1 = new BigDecimal(Double.toString(v1));
        BigDecimal b2 = new BigDecimal(Double.toString(v2));
        return b1.add(b2).doubleValue();
    }
 输出:8.694

 

由此引出减法的计算:

    /**
     * 提供精确的减法运算。
     * @param v1 被减数
     * @param v2 减数
     * @return 两个参数的差
     */
     public static double sub(double v1,double v2){
         BigDecimal b1 = new BigDecimal(Double.toString(v1));
         BigDecimal b2 = new BigDecimal(Double.toString(v2));
         return b1.subtract(b2).doubleValue();
     }

 

乘法的计算:

     /**
      * 提供精确的乘法运算。
      * @param v1 被乘数
      * @param v2 乘数
      * @return 两个参数的积
      */
      public static double mul(double v1,double v2) {
          BigDecimal b1 = new BigDecimal(Double.toString(v1));
          BigDecimal b2 = new BigDecimal(Double.toString(v2));
          return b1.multiply(b2).doubleValue();
      }

 

 除法的计算:

      /**
       * 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到
       * 小数点以后10位,以后的数字四舍五入。
       * @param v1 被除数
       * @param v2 除数
       * @return 两个参数的商
       */
       public static double div(double v1,double v2) {
           return div(v1,v2,10);
       }
       /**
       * 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指
       * 定精度,以后的数字四舍五入。
       * @param v1 被除数
       * @param v2 除数
       * @param scale 表示表示需要精确到小数点以后几位。
       * @return 两个参数的商
       */
       public static double div(double v1,double v2,int scale){
           if(scale<0){
               throw new IllegalArgumentException("The scale must be a positive integer or zero");
           }
           BigDecimal b1 = new BigDecimal(Double.toString(v1));
           BigDecimal b2 = new BigDecimal(Double.toString(v2));
           return b1.divide(b2,scale,BigDecimal.ROUND_HALF_UP).doubleValue();
       }

 

提供精确的小数位四舍五入处理:

       /**
        * 提供精确的小数位四舍五入处理。
        * @param v 需要四舍五入的数字
        * @param scale 小数点后保留几位
        * @return 四舍五入后的结果
        */
        public static double round(double v,int scale) {
            if(scale<0){
                throw new IllegalArgumentException("The scale must be a positive integer or zero");
            }
            BigDecimal b = new BigDecimal(Double.toString(v));
            BigDecimal one = new BigDecimal("1");
            return b.divide(one,scale,BigDecimal.ROUND_HALF_UP).doubleValue();
        }
 
分享到:
评论

相关推荐

    float、double类型介绍.zip

    标题中的“float、double类型介绍”指的是在编程语言中,如C++、Java或Python等,用于表示浮点数的数据类型。浮点数是计算机科学中用来表示小数的一种方式,因为它们不是精确的,而是近似的。浮点类型通常分为两种...

    详解java中float与double的区别

    float 和 double 是 Java 中两种基本数据类型,都是用来表示实数的,但是它们有很大的区别。float 是单精度类型,精度是 8 位有效数字,取值范围是 10 的 -38 次方到 10 的 38 次方,float 占用 4 个字节的存储空间...

    Java数据类型和MySql数据类型对应一览

    Java 数据类型和 MySql 数据类型对应一览 在 Java 编程语言中,数据类型是指变量或函数可以持有的值的类型。 MySql 数据库也具有其自己的数据类型,用于存储和管理数据。在本文中,我们将对 Java 数据类型和 MySql ...

    Java数据类型和MySql数据类型对应表

    Java 数据类型和 MySql 数据类型对应表 在 Java 编程中,了解 Java 数据类型和 MySql 数据类型的对应关系非常重要。这是因为在 Java 应用程序中,我们经常需要与数据库进行交互,而 MySql 是一种常用的关系数据库...

    java、mysql以及oracle数据类型对照表

    在IT行业中,数据库管理和编程是...总的来说,掌握Java、MySQL和Oracle之间的数据类型对应是提升开发效率和代码质量的关键。通过深入理解和运用这些知识,开发人员能更好地设计和实现跨平台的数据存储和检索解决方案。

    sqlserver数据库类型对应Java中的数据类型

    在 Java 中,float 对应的数据类型是 double。 int 在 SQL Server 中,int 是一个整数类型,用于存储整数值。在 Java 中,int 对应的数据类型是 int。 image 在 SQL Server 中,image 是一个二进制类型,用于...

    Java实现IEE754 Float类型数据

    ### Java实现IEEE 754 Float类型数据解析 在计算机科学领域中,浮点数的表示方式至关重要,尤其是在处理科学计算、图形渲染等对精度有较高要求的应用场景中。IEEE 754标准定义了一种广泛使用的浮点数表示方法,它被...

    Oracle9i数据类型Java数据类型Schema类型对比.doc

    Oracle9i 数据类型、Java 数据类型以及 Schema 类型之间的对比主要关注它们在存储和处理数据时的差异。这些数据类型是编程和数据库管理中的基础,理解它们的关系对于开发与数据库交互的应用程序至关重要。 1. ...

    Java实验-基本数据类型及操作

    Java中的基本数据类型包括整型(int)、浮点型(float、double)、布尔型(boolean)、字符型(char)和字符串型(String)。每种数据类型都有其特定的存储空间和取值范围。 1. 整型(int):整型变量用于存储整数...

    Mysql、orcale 中的数据类型与java中的数据类型对应表.pdf

    在 Java 中,对应 MySQL 的数值类型可以使用基本数据类型,例如 int、long、float 和 double 等。对应日期时间类型可以使用 java.util.Date 和 java.sql.Date 等。对应字符串类型可以使用 String 等。 理解 MySQL ...

    解决java数值范围以及float与double精度丢失的问题

    Java中的基本数据类型有多种,包括整数类型(int、long)、浮点数类型(float、double)。每种类型都有其对应的数值范围。 1. 整数类型(int、long) 整数类型的数值范围取决于其bit数。int类型的bit数为32位,...

    JAVA数据类型思维导图

    在这个案例中,"数据类型.png"和"data类型.xmind"文件可以帮助初学者更好地理解Java数据类型之间的关系和层次结构,从而加深对数据类型的掌握。 7. 使用提示 - 对于初学者,理解并熟练掌握数据类型是学习Java的第...

    java数据类型的转换简单数据类型之间的转换 (2). 字符串与其它数据类型的转换 (3). 其它实用数据类型转换

    一些初学JAVA的朋友可能会遇到JAVA的数据类型之间转换的苦恼,例如,整数和float,double型之间的转换,整数和String类型之间的转换,以及处理、显示时间方面的问下面笔者就开发中的一些体会介绍给大家。 我们知道,...

    MySql于Java数据类型对应列表

    本文将详细介绍MySQL中的各种数据类型及其在Java中的对应类型,并解释这些类型的具体含义以及它们在实际应用中的作用。 #### 数据类型对照表解析 ##### 1. VARCHAR (可变长度字符串) **显示长度:** L+N **数据库...

    java数据类型汇总

    Java 数据类型是编程的基础,了解并熟练掌握它们的特性及转换方式对于任何Java开发者来说都至关重要。Java的数据类型主要分为两大类:基本数据类型(Primitive Data Types)和引用数据类型(Reference Data Types)...

    Java数据类型操作包含转换代码实例.rar

    这个压缩包“Java数据类型操作包含转换代码实例.rar”提供了丰富的代码示例,帮助初学者理解和掌握Java中数据类型的转换。下面将详细阐述相关知识点。 一、基本数据类型 Java的基本数据类型包括整型(byte, short, ...

    Java数据类型练习.doc

    Java 数据类型练习 本文档总结了 Java 数据类型的一些基本概念和实践练习题,涵盖了基本类型、变量定义、常量、运算符、控制流、数组、随机数等多方面的知识点。 一、基本类型 Java 中有八种基本类型:byte、...

    java的八大基础数据类型

    Java 的八大基础数据类型是 Java 语言的一部分,分别是 byte, short, int, long, char, float, double, boolean。下面分别对每种数据类型进行详细介绍: 一、整型 整型在 Java 中分为四种:byte, short, int, long...

    Java中几种常用数据类型之间转换的方法

    Java 中几种常用数据类型之间转换的方法 Java 是一种基于对象的编程语言,它支持多种数据类型之间的转换,这些转换在实际编程中非常有用。本文将介绍 Java 中几种常用的数据类型之间转换方法。 1. short --&gt; int ...

    Java 字符串和基本数据类型之间的转换

    在Java编程语言中,字符串(String)和基本数据类型之间的转换是常见的操作,特别是在处理用户输入、格式化输出或解析数据时。以下将详细介绍如何在Java中进行这些转换。 1. **字符串转基本数据类型** - **整型(int...

Global site tag (gtag.js) - Google Analytics