double和float的区别与使用

news2024/10/1 17:41:44

double和float类型的区别与使用

  1. 在Java中,double和float都是基本数据类型,用于表示浮点数(即带有小数点的数)。
    • 它们在精度和范围上有所不同:
      • double类型提供了更高的精度和更大的范围,而float类型则精度更低,范围更少;
    • 声明这些类型的变量时,你需要遵循特定的语法规则。
      在这里插入图片描述

double 类型

  1. double类型的变量用于存储双精度浮点数。当你声明一个double类型的变量时,你不需要在数值后面加上任何特定的后缀(尽管在某些情况下,加上D或d后缀可以明确表示这是一个double类型的字面量,但这对于变量声明本身不是必需的)。
    • 使用一个浮点数字面量(如3.14),Java会将其视为double类型
    • 如果直接使用一个整型(如10),Java会进行自动类型转换,即从int 自动转换 为double类型。
double md = 3.14; // 3.14就是double类型的数据  
double ad = 3.0; // 注意:即使没有小数部分,这也是一个double类型的浮点数
double c = 3;// 自动类型转换(int-》double)
double d = 10.0d;
double e = 10D;
  • 自动类型转换:精度小的类型自动转换为精度大的数据类型。
    • 数据类型按精度(容量)大小排序为:char—>int–>long–>float–>double或者byte–>short–>int–>long–>float–>double

float 类型

  1. float类型的变量用于存储单精度浮点数
    • 在声明float类型的变量并给它赋值时:
      • 如果你直接使用一个浮点数字面量(如3.14),Java会将其视为double类型因为浮点数字面量默认是double类型的。为了避免编译错误,你需要在数值后面加上F或f后缀来明确表示这是一个float类型的字面量。(或者使用 强制类型转换,不建议,会产生精度损失)
      • 如果直接使用一个整型(如3),Java会进行自动类型转换,即从int 自动转换 为float类型。
float j = 3.14;//这个会报错的,double不可以自动转换为float类型

float m = 3.14f;  
float n = 3.0f; // 必须加上f或F后缀
float a = 3;//这个也可以(自动类型转换)

例题:分别有三个变量,a,b,c,请问一下的定义中哪些有错误:float a=2;float b=2.5;float c=3.0f

Float b = 2.5;存在语法错误,在Java中2.5是double类型的数据,不能自动转换为float类型的数据(可以使用强制类型转换,但是会有精度损失的风险,不建议),所以应该改成float b= 2.5f;

Float a= 2;虽然没有语法错误,但是也存在一定的风险,因为2是一个int类型的数据,它会产生自动类型转换,有int转换为float。所以最好是改成float = 2f;

总结

  • double类型的变量用于存储双精度浮点数,可以表示更大范围和更高精度的浮点数。
  • float类型的变量用于存储单精度浮点数,范围和精度较小。
  • 在声明float类型的变量并赋值时,需要在浮点数字面量后加上F或f后缀,以明确表示这是一个float类型的字面量。double类型的字面量在赋值给double类型变量时不需要特殊后缀(也可以加D或d)。

double和float的精度损失的问题解决

  • 使用BigDecimal类:在Java中,BigDecimal类提供了一种精确的浮点数计算方式。这个类可以表示任意精度的十进制数,并且可以执行精确的数学运算。当需要处理精确的小数运算时,可以使用BigDecimal来代替基本数据类型float和double。
    • double和float类型的数据进行运算时,是可能发生精度损失,不是一定会发生精度损失的问题
		double a =0.1;
        double b = 0.2;
        System.out.println(a + b);//0.30000000000000004
        System.out.println(a * b);//0.020000000000000004

        BigDecimal c = new BigDecimal("0.1");
        BigDecimal d = new BigDecimal("0.2");
        BigDecimal sum = c.add(d); //求和
        System.out.println(sum);// 结果为 0.3
        BigDecimal ji = c.multiply(d);//乘积
        System.out.println(ji);// 结果为0。02
  • 设置浮点数的精度:如果必须使用float或double类型,并且可以接受一定程度的精度损失,可以通过设置浮点数的小数点后的位数来尽量减小误差。这通常通过四舍五入等方式实现,但需要注意,这并不能完全避免精度丢失。
  • 避免不必要的浮点数运算:在算法设计时,尽量避免不必要的浮点数运算,或者通过数学变换将浮点数运算转化为整数运算。例如,在计算百分比时,可以先将百分比乘以100转换为整数进行计算,最后再除以100得到结果。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1912919.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

类似评论、省市区这种具有层次结构的数据表怎么设计?

业务功能模块 评论、回复模块省市区表 设置一个给每个数据设置一个parent_id 例如: 某个视频下a写了条评论,那a的parent_id就是0;b回复了a,那b的parent_id就是a的id;c回复了b,那c的parent_id就是b的id; 这样,所有评论…

MATLAB备赛资源库(1)建模指令

一、介绍 MATLAB(Matrix Laboratory)是一种强大的数值计算环境和编程语言,特别设计用于科学计算、数据分析和工程应用。 二、使用 数学建模使用MATLAB通常涉及以下几个方面: 1. **数据处理与预处理**: - 导入和处理…

LeetCode加油站(贪心算法/暴力,分析其时间和空间复杂度)

题目描述 一.原本暴力算法 最初的想法是:先比较gas数组和cost数组的大小,找到可以作为起始点的站点(因为如果你起始点的油还不能到达下一个站点,就不能作为起始点)。当找到过后,再去依次顺序跑一圈,如果剩余的油为负数…

java使用poi-tl模版引擎导出word之if判断条件的使用

文章目录 模版中if语句条件的使用1.数据为False或空集合2.非False或非空集合 模版中if语句条件的使用 如果区块对的值是 null 、false 或者空的集合,位于区块中的所有文档元素将不会显示,这就等同于if语句的条件为 false。语法示例:{{?stat…

FUSE(用户空间文件系统)命令参数

GPT-4 (OpenAI) FUSE (Filesystem in Userspace)是一个允许创建用户空间文件系统的接口。它提供了一个API,让开发者在未修改内核代码的情况下,通过自己的程序实现文件系统。FUSE 文件系统通常通过 mount 命令来挂载,而且这个命令可以接受各…

【福利】代码公开!咸鱼之王自动答题脚本

转载请注明出处:小锋学长生活大爆炸[xfxuezhagn.cn] 如果本文帮助到了你,欢迎[点赞、收藏、关注]哦~ 微信或QQ打开咸鱼之王小程序,进入答题界面,运行main.py。期间不要动鼠标。 可自行更改代码来适配自己的需求~ 可以按照示例图片…

用QFramework重构飞机大战(Siki Andy的)(上)(00-05 到游戏界面之前的所有面板)

GitHub // 官网的 全民飞机大战(第一季)-----框架设计篇(Unity 2017.3) 全民飞机大战(第二季)-----游戏逻辑篇(Unity 2017.3) 全民飞机大战(第三季)-----完善…

基于Java的学生选课系统

第1章 系统概述 1.1概述 背景:随着计算机网络技术的发展,Web 数据库技术已成为应用最为广泛的网站架构基础技术。学生选课系统作为教育单位不可缺少的部分,其内容对于学校的决策者和管理者至关重要。传统的人工管理方式存在效率低、保密性差等…

HarmonyOS ArkUi 字符串<展开/收起>功能

效果图: 官方API: ohos.measure (文本计算) 方式一 measure.measureTextSize 跟方式二使用一样,只是API调用不同,可仔细查看官网方式二 API 12 import { display, promptAction } from kit.ArkUI import { MeasureUtils } fr…

字节码编程javassist之生成带有注解的类

写在前面 本文看下如何使用javassist生成带有注解的类。 1:程序 测试类 package com.dahuyou.javassist.huohuo.cc;import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import ja…

综合安全防护

题目 1,DMZ区内的服务器,办公区仅能在办公时间内(9:00-18:00)可以访问,生产区的设备全天可以访问. 2,生产区不允许访问互联网,办公区和游客区允许访问互联网 3,办公区设备10.0.2.10不允许访问DMz区的FTP服务器和HTTP服务器,仅能ping通10.0.3.10 4,办公区分为市场部和研发部,研…

【实战场景】大文件解析入库的方案有哪些?

【实战场景】大文件解析入库的方案有哪些? 开篇词:干货篇:分块解析内存映射文件流式处理数据库集群处理分布式计算框架 总结篇:我是杰叔叔,一名沪漂的码农,下期再会! 开篇词: 需求背…

【爬虫】Python实现,模拟天眼查登录验证获取token

模拟天眼查登录验证获取token 项目介绍逻辑思路效果演示部分代码展示源代码获取 项目介绍 注:本程序测试时期:2024.7.9,稳定可用 天眼查登录接口升级更新之后,后台接口login接口登录运用了4代极验gt,js逆向部分相当复…

Python | Leetcode Python题解之第225题用队列实现栈

题目: 题解: class MyStack:def __init__(self):"""Initialize your data structure here."""self.queue collections.deque()def push(self, x: int) -> None:"""Push element x onto stack."&…

FPGA 项目菜单功能比较

为了帮助您更好地理解每个FPGA功能模块的实用场合、区别和特点,以下是详细的比较: 功能模块实用场合区别特点FPGA I/O自动控制系统、数据采集系统直接与FPGA板卡上的物理端口交互,配置和使用外部I/O设备灵活配置输入输出端口,支持…

面试官:讲一下如何终止一个 Promise 继续执行

我们知道 Promise 一旦实例化之后,状态就只能由 Pending 转变为 Rejected 或者 Fulfilled, 本身是不可以取消已经实例化之后的 Promise 了。 但是我们可以通过一些其他的手段来实现终止 Promise 的继续执行来模拟 Promise 取消的效果。 Promise.race …

4.MkDocs样式

学习 Admonitions(警告) - Material for MkDocs (wdk-docs.github.io) 提示 - Material for MkDocs 中文文档 (llango.com) Buttons(按钮) - Material for MkDocs (wdk-docs.github.io) 建议去看这些网站,更为详细。 常用功能 便利贴 ​​ 开启 markdown_ex…

通用后台管理(二)——项目搭建

目录 前言 一、安装vue-cli依赖 1、使用yarn下载vue-cli 2、使用npm下载 3、检查一下是否下载成功 二、创建项目 1、创建项目,my-app是项目名称 2、 这里选择vue 2,蓝色表示选中的。 3、启动项目 三、下载项目依赖 四、配置项目 1、修改esli…

“Numpy数据分析与挖掘:高效学习重点技能“

目录 # 开篇 # 补充 zeros & ones eye 1. numpy数组的创建 1.1 array 1.2 range 1.3 arange 1.4 常见的数据类型 1.5 astype 1.6 random.random() & round 2. numpy数组计算和数组计算 2.1 reshape 2.2 shape 2.3 将一维数组变成多维数组 2.4 指定一维…

理解算法复杂度:空间复杂度详解

引言 在计算机科学中,算法复杂度是衡量算法效率的重要指标。时间复杂度和空间复杂度是算法复杂度的两个主要方面。在这篇博客中,我们将深入探讨空间复杂度,了解其定义、常见类型以及如何进行分析。空间复杂度是衡量算法在执行过程中所需内存…