JAVA中一个float除以一个int变量,得到的结果精确到几位?

供稿:hz-xin.com     日期:2025-01-14
JAVA里INT除以INT类型得的结果为FLOAT或者DOUBLE怎样做?

用强制转换,比如

double c = (double)a/b;

这样把a强制转换为double来计算,double/int 得到的就是double;
当然float同理.

这个不是属于结果出错,只是计算的精度的问题。
这里计算的精度到底是你的计算器精度不够还是你的程序精度不够呢?你要验证一下才知道的。
现实中很少有用到小数点后4位之后的。这个问题我觉得不用太过计较。

我们知道,Java的数据类型分为三大类,即布尔型、字符型和数值型,而其中数值型又分为整型和浮点型;相对于数据类型,Java的变量类型为布尔型boolean;字符型char;整型byte、short、int、long;浮点型float、double。其中四种整型变量和两种浮点型变量分别对应于不同的精度和范围。此外,我们还经常用到两种类变量,即String和Date。对于这些变量类型之间的相互转换在我们编程中经常要用到,在下面的论述中,我们将阐述如何实现这些转换。

1 数据类型转换的种类\r
java数据类型的转换一般分三种,分别是:
(1). 简单数据类型之间的转换
(2). 字符串与其它数据类型的转换
(3). 其它实用数据类型转换
下面我们对这三种类型转换分别进行论述。
2 简单数据类型之间的转换
在Java中整型、实型、字符型被视为简单数据类型,这些类型由低级到高级分别为
[center](byte,short,char)--int--long--float--double[/center]
简单数据类型之间的转换又可以分为:
●低级到高级的自动类型转换
●高级到低级的强制类型转换
●包装类过渡类型能够转换

2.1自动类型转换
低级变量可以直接转换为高级变量,笔者称之为自动类型转换,例如,下面的语句可以在Java中直接通过:

byte b;int i=b;long l=b;float f=b;double d=b;

如果低级类型为char型,向高级类型(整型)转换时,会转换为对应ASCII码值,例如\r

char c='c'; int i=c; System.out.println("output:"+i);

输出:output:99;
对于byte,short,char三种类型而言,他们是平级的,因此不能相互自动转换,可以使用下述的强制类型转换。

short i=99;char c=(char)i;System.out.println("output:"+c);

输出:output:c;
但根据笔者的经验,byte,short,int三种类型都是整型,因此如果操作整型数据时,最好统一使用int型。

2.2强制类型转换
将高级变量转换为低级变量时,情况会复杂一些,你可以使用强制类型转换。即你必须采用下面这种语句格式:

int i=99;byte b=(byte)i;char c=(char)i;float f=(float)i;

可以想象,这种转换肯定可能会导致溢出或精度的下降,因此笔者并不推荐使用这种转换。

2.3包装类过渡类型转换
在我们讨论其它变量类型之间的相互转换时,我们需要了解一下Java的包装类,所谓包装类,就是可以直接将简单类型的变量表示为一个类,在执行变量类型的相互转换时,我们会大量使用这些包装类。Java共有六个包装类,分别是Boolean、Character、Integer、Long、Float和Double,从字面上我们就可以看出它们分别对应于 boolean、char、int、long、float和double。而String和Date本身就是类。所以也就不存在什么包装类的概念了。
在进行简单数据类型之间的转换(自动转换或强制转换)时,我们总是可以利用包装类进行中间过渡。
一般情况下,我们首先声明一个变量,然后生成一个对应的包装类,就可以利用包装类的各种方法进行类型转换了。例如:
例1,当希望把float型转换为double型时:

float f1=100.00f; Float F1=new float(f1); Double d1=F1.doubleValue();//F1.doubleValue()为Float类的返回double值型的方法

当希望把double型转换为int型时:

double d1=100.00; Double D1=new Double(d1); int i1=D1.intValue();

当希望把int型转换为double型时,自动转换:

int i1=200; double d1=i1;

简单类型的变量转换为相应的包装类,可以利用包装类的构造函数。即:
Boolean(boolean value)、Character(char value)、Integer(int value)、Long(long value)、Float(float value)、Double(double value)
而在各个包装类中,总有形为××Value()的方法,来得到其对应的简单类型数据。利用这种方法,也可以实现不同数值型变量间的转换,例如,对于一个双精度实型类,intValue()可以得到其对应的整型变量,而doubleValue()可以得到其对应的双精度实型变量。

3 字符串型与其它数据类型的转换
通过查阅类库中各个类提供的成员方法可以看到,几乎从java.lang.Object类派生的所有类提供了toString()方法,即将该类转换为字符串。例如:Characrer,Integer,Float,Double,Boolean,Short等类的toString()方法toString()方法用于将字符、整数、浮点数、双精度数、逻辑数、短整型等类转换为字符串。如下所示:

int i1=10;float f1=3.14f;double d1=3.1415926;Integer I1=new Integer(i1);//生成Integer类\rFloat F1=new Float(f1); //生成Float类\rDouble D1=new Double(d1); //生成Double类\r//分别调用包装类的toString()方法转换为字符串String si1=I1.toString();String sf1=F1.toString();String sd1=D1.toString();Sysytem.out.println("si1"+si1);Sysytem.out.println("sf1"+sf1);Sysytem.out.println("sd1"+sd1);

这个问题很奇怪,所以花时间写了个程序测试了一下:
public class Test {
public static void main(String[] args) {
System.out.println(Math.PI/2);
}
}
得到结果:
1.5707963267948966
得到结论:
如果结果是无理数或者小数位数大于16,那么取16位
如果结果不是无理数并且小数位数小于或者等于16位,那么最后的结果的精确度就是结果本身的小数位!

按flaot的精度来计算的。至于flaot的精度是多少么,只有看JAVA对flaot的介绍了。对好不要用flaot计算精度有问题,建议用那个双精度类型,double

当然试按float计算了
int Integer 4个字节 long Long 8个字节 float Float 4个字节 double Double 8个字节 byte Byte...
按精确度高的算

int与Integer的区别
int 是基本数据类型 Integer是其包装类,注意是一个类。为什么要提供包装类呢???一是为了在各种类型间转化,通过各种方法的调用。否则 你无法直接通过变量转化。比如,现在int要转为String int a=0;String result=Integer.toString(a);在java中包装类,比较多的用途是用在于各种数据类型的转化中。我...

51单片机怎么通过串口发送小数?
方法多的去了,把数字37.5转换为字符串“37.5”发送可以,用压缩BCD码0x37、0x05发送也可以,多得是。不一定一定要浮点处理。

帮我起个英文名 F打头的 我是女生
他们当中,有一个英雄名叫Finn,又名Fionn或Fingal。此外,人们还传说古爱尔兰住着一位『白肩姑娘』(克尔特语为Fionnguala,她是李尔王的女儿。后来她变为天鹅,在漫长的几百年间,游荡在爱尔兰的河川湖泊中。FRANCES (拉丁)"自由,来自法国;FRANCIS的女性名。大部份的人认为FRANCES是个纤弱保守的女子,...

Java语言的特点
另外,现实世界中任何实体都可归属于某类事物,任何对象都是某一类事物的实例。如果说传统的过程式编程语言是以过程为中心以算法为驱动的话,面向对象的编程语言则是以对象为中心以消息为驱动。用公式表示,过程式编程语言为:程序=算法+数据;面向对象编程语言为:程序=对象+消息。 所有面向对象编程语言都支持三个概念:...