热门标签 | 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



推荐阅读
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • 本文介绍了一个Java猜拳小游戏的代码,通过使用Scanner类获取用户输入的拳的数字,并随机生成计算机的拳,然后判断胜负。该游戏可以选择剪刀、石头、布三种拳,通过比较两者的拳来决定胜负。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文介绍了在Java中gt、gtgt、gtgtgt和lt之间的区别。通过解释符号的含义和使用例子,帮助读者理解这些符号在二进制表示和移位操作中的作用。同时,文章还提到了负数的补码表示和移位操作的限制。 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • 本文介绍了一种划分和计数油田地块的方法。根据给定的条件,通过遍历和DFS算法,将符合条件的地块标记为不符合条件的地块,并进行计数。同时,还介绍了如何判断点是否在给定范围内的方法。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • Java String与StringBuffer的区别及其应用场景
    本文主要介绍了Java中String和StringBuffer的区别,String是不可变的,而StringBuffer是可变的。StringBuffer在进行字符串处理时不生成新的对象,内存使用上要优于String类。因此,在需要频繁对字符串进行修改的情况下,使用StringBuffer更加适合。同时,文章还介绍了String和StringBuffer的应用场景。 ... [详细]
  • 本文介绍了解决二叉树层序创建问题的方法。通过使用队列结构体和二叉树结构体,实现了入队和出队操作,并提供了判断队列是否为空的函数。详细介绍了解决该问题的步骤和流程。 ... [详细]
  • 本文介绍了C函数ispunct()的用法及示例代码。ispunct()函数用于检查传递的字符是否是标点符号,如果是标点符号则返回非零值,否则返回零。示例代码演示了如何使用ispunct()函数来判断字符是否为标点符号。 ... [详细]
  • 本文介绍了Java高并发程序设计中线程安全的概念与synchronized关键字的使用。通过一个计数器的例子,演示了多线程同时对变量进行累加操作时可能出现的问题。最终值会小于预期的原因是因为两个线程同时对变量进行写入时,其中一个线程的结果会覆盖另一个线程的结果。为了解决这个问题,可以使用synchronized关键字来保证线程安全。 ... [详细]
  • 本文探讨了C语言中指针的应用与价值,指针在C语言中具有灵活性和可变性,通过指针可以操作系统内存和控制外部I/O端口。文章介绍了指针变量和指针的指向变量的含义和用法,以及判断变量数据类型和指向变量或成员变量的类型的方法。还讨论了指针访问数组元素和下标法数组元素的等价关系,以及指针作为函数参数可以改变主调函数变量的值的特点。此外,文章还提到了指针在动态存储分配、链表创建和相关操作中的应用,以及类成员指针与外部变量的区分方法。通过本文的阐述,读者可以更好地理解和应用C语言中的指针。 ... [详细]
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社区 版权所有