热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

float类型转integer_【第3章:Java基础程序设计】_Java数据类型

数据溢出当定义一个变量的值超过该变量类型的范围时会导致数据溢出,编译都无法通过publicclassTestJava{publicstaticvoidmain(Str

 数据溢出

当定义一个变量的值超过该变量类型的范围时会导致数据溢出,编译都无法通过

public class TestJava{

       public static void main(String args[]){

              int n=99999999999999999999999999999999;

       }

}

818fbfbba22648641eb1755702664425.png

Integer(int最大范围)的最大值

public class TestJava{

       public static void main(String args[]){

              int n=Integer.MAX_VALUE;

              System.out.print(n);

       }

}

73e69c828935694ba95982f6888df6c3.png

最大值加1是最小值,再加1就是次小值依此类推

public class TestJava{

       public static void main(String args[]){

              int n=Integer.MAX_VALUE;

              System.out.println(n+1);

              System.out.println(n+2);

       }

}

609d11d477c737b9b5cf3f77b1f30ab7.png

用长整型强制转换可以解决最大值加1就是最小值的问题

public class TestJava{

       public static void main(String args[]){

              int n=Integer.MAX_VALUE;

              System.out.println((long)n+2);

       }

}

f22e265edfa5b1917ac3ca34d62a1b59.png

字符的本质也是数值(ascill码),所以字符不仅仅单双引号进行定义,只要是char类型,则也可以用数值代替

public class TestJava{

       public static void main(String args[]){

              char ch1='a';

              char ch2=97;

              System.out.println(ch1);

              System.out.println(ch2);

       }

}

11c462c07d78387c038e4cd5755bfd86.png

转义字符

public class TestJava{

       public static void main(String args[]){

              char ch1='\"';

              char ch2='\\';

              System.out.println(ch1);

              System.out.println(ch2);

       }

}

687a8fa5b1196d8a34f8c20efd709e6b.png

定义浮点型数据要指定精度,否则默认精度会有默认转换的情况损失精度

这里定义浮点型3.0,那么也就是说要的是float的目的数据,而默认是double,double转换到float是会损失精度的。

public class TestJava{

       public static void main(String args[]){

              float num=3.0;

       }

}

a352bb101a88a4a653355f269d3612c1.png

指定精度后就没有问题了

public class TestJava{

       public static void main(String args[]){

              float num=3.0f;

       }

}

d794918d346e0b5d931c8ade40776b0d.png

布尔类型

public class TestJava{

       public static void main(String args[]){

              boolean flag=true;

              System.out.print(flag);

       }

}

5aa89dad9ff1816b4e57113a85b948cc.png

自动转型

这里整数除以浮点型最后的结果自动转换为浮点型了。

public class TestJava{

       public static void main(String args[]){

              int x=30;

              float y=22.19f;

              System.out.print(x/y);

       }

}

4c75a080c8f4514b62363ee7a2051c7c.png

public class TestJava{

       public static void main(String args[]){

              System.out.print(10/3.5);

       }

}

d2cabf88d35fb6164e2959b4f1e857ee.png

整型相除问题

这里相除的结果很明显损失了精度

public class TestJava{

       public static void main(String args[]){

              System.out.print(10/3);

       }

}

e7823ff2e4691cf71da549cf4f520bc5.png

用强转float可以解决该问题

public class TestJava{

       public static void main(String args[]){

              System.out.print((float)10/3);

       }

}

3db01b6d9639ce41b7dbd30321e14ae1.png

字符串与int的运算

public class TestJava{

       public static void main(String args[]){

              String str="gaojiupan";

              int x=30;

              str=str+x;

              System.out.print(str);

       }

}

上面这是正常情况,再看一个比较异常的情况

public class TestJava{

       public static void main(String args[]){

              System.out.print("1+2="+1+2);

       }

}

624721596ecc4a0b42032bee787d8751.png

这种情况是字符串直接进行追加了,没有把后面两个先计算再追加,像是下面这样就好了

public class TestJava{

       public static void main(String args[]){

              System.out.print("1+2="+(1+2));

       }

}

2c8ea851dea2317399c58a4f4e67cbb7.png

强制类型转换丢失精度

public class TestJava{

       public static void main(String args[]){

              float f=30.3f;

              int x=(int)f;

              System.out.print(x);

       }

}

ec0c88f97a71e1c2e19c81b39cfc8174.png



推荐阅读
  • 本文探讨了在C++中如何有效地清空输入缓冲区,确保程序只处理最近的输入并丢弃多余的输入。我们将介绍一种不阻塞的方法,并提供一个具体的实现方案。 ... [详细]
  • 开发笔记:9.八大排序
    开发笔记:9.八大排序 ... [详细]
  • 异常要理解Java异常处理是如何工作的,需要掌握一下三种异常类型:检查性异常:最具代表性的检查性异常是用户错误或问题引起的异常ÿ ... [详细]
  • 深入解析Java枚举及其高级特性
    本文详细介绍了Java枚举的概念、语法、使用规则和应用场景,并探讨了其在实际编程中的高级应用。所有相关内容已收录于GitHub仓库[JavaLearningmanual](https://github.com/Ziphtracks/JavaLearningmanual),欢迎Star并持续关注。 ... [详细]
  • 本题来自WC2014,题目编号为BZOJ3435、洛谷P3920和UOJ55。该问题描述了一棵不断生长的带权树及其节点上小精灵之间的友谊关系,要求实时计算每次新增节点后树上所有可能的朋友对数。 ... [详细]
  • 实用正则表达式有哪些
    小编给大家分享一下实用正则表达式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下 ... [详细]
  • 本文探讨了如何通过预处理器开关选择不同的类实现,并解决在特定情况下遇到的链接器错误。 ... [详细]
  • 本题探讨了在一个有向图中,如何根据特定规则将城市划分为若干个区域,使得每个区域内的城市之间能够相互到达,并且划分的区域数量最少。题目提供了时间限制和内存限制,要求在给定的城市和道路信息下,计算出最少需要划分的区域数量。 ... [详细]
  • 本文详细介绍了C语言的起源、发展及其标准化过程,涵盖了从早期的BCPL和B语言到现代C语言的演变,并探讨了其在操作系统和跨平台编程中的重要地位。 ... [详细]
  • 深入理解Lucene搜索机制
    本文旨在帮助读者全面掌握Lucene搜索的编写步骤、核心API及其应用。通过详细解析Lucene的基本查询和查询解析器的使用方法,结合架构图和代码示例,带领读者深入了解Lucene搜索的工作流程。 ... [详细]
  • JavaScript 基础语法指南
    本文详细介绍了 JavaScript 的基础语法,包括变量、数据类型、运算符、语句和函数等内容,旨在为初学者提供全面的入门指导。 ... [详细]
  • 本文将探讨Java编程语言中对象和类的核心概念,帮助读者更好地理解和应用面向对象编程的思想。通过实际例子和代码演示,我们将揭示如何在Java中定义、创建和使用对象。 ... [详细]
  • Java 实现二维极点算法
    本文介绍了一种使用 Java 编程语言实现的二维极点算法。该算法用于从一组二维坐标中筛选出极点,适用于需要处理几何图形和空间数据的应用场景。文章不仅详细解释了算法的工作原理,还提供了完整的代码示例。 ... [详细]
  • 深入理解Java字符串池机制
    本文详细解析了Java中的字符串池(String Pool)机制,探讨其工作原理、实现方式及其对性能的影响。通过具体的代码示例和分析,帮助读者更好地理解和应用这一重要特性。 ... [详细]
  • ------------------------------————————————————————————————1.定义一个类,实现与被增强对象相同的接口2.在类中定义一个对象,记住被增强 ... [详细]
author-avatar
杜亮亮喜欢2602936263
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有