我的应用正在生成double,其中Double.toString()生成“-3.1999999999999953”——而我希望它生成“-3.2”。我实际上是从JScience的Amount#getEstimatedValue()得到这些double的.我不想为精度设置任意位数,因为我不知道有多少位数是有效的,但我不希望它生成以“99999999.*”结尾的数字。如何在没有这个问题的情况下将double转换为字符串? 最佳答案 推荐方案BigDecimal.valueOf(hisDouble).toPlainString()在尝试解决
如何获取double或float的单个位(或整个变量)?例如如果我有floata=0.5;我希望String等于:“00111111000000000000000000000000”或十六进制:“F000000” 最佳答案 对于Java,float在32位上像int,而double在64位上像long。找到这些数字的二进制表示,您需要:floata=0.5f;intbits=Float.floatToIntBits(a);String.format("%32s",Integer.toBinaryString(bits)).repla
我的程序接收到一些输入(String)。输入很可能是double的形式,比如"1.5"。但我想将其转换为integer,这样我就可以得到1。首先,我尝试了这个:Integer.parseInt(someString);但它不起作用-我假设这是因为点.它无法解析它。所以我想也许Integer类可以从double创建一个integer。所以我决定创建一个double,然后将其设为int,如下所示:Integer.parseInt(Double.parseDouble(someString));但显然有nosuitablemethodfoundforparseInt(double)那么,你有
我有一个名为out的ArrayList,我需要将它转换为double[]。我在网上找到的例子说明了两件事:首先,尝试:double[]d=newdouble[out.size()];out.toArray(d);但是,这会产生错误(eclipse):ThemethodtoArray(T[])inthetypeListisnotapplicableforthearguments(double[]).我在StackOverflow上找到的第二个解决方案是:double[]dx=Arrays.copyOf(out.toArray(),out.toArray().length,double[]
所以我在这里要做的是获取一个float[],将其转换为byte[],将其作为数据报包通过网络发送,然后然后在接收终端将其转换回byte[]。现在我知道我可以使用getBytes[]方法将float[]转换为byte[]。但我不知道如何反转转换。 最佳答案 我想你想使用ByteBuffer类,它有putFloat和getFloat方法。 关于java-将float[]转换为byte[]再转换为float[],我们在StackOverflow上找到一个类似的问题:
sunjdk实现如下所示:returnv!=v;谁能解释一下它是如何工作的? 最佳答案 NaN值不等于任何值(如果等式的一侧为NaN,则等式为假),因此NaN!=NaN。显然每个正常的double都等于自己 关于java-Double.isNaN()是如何工作的?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/2678985/
如何从byte[](Blob)获取文件类型扩展名。我正在从数据库读取文件到byte[]但我不知道如何自动检测文件扩展名。Blobblob=rs.getBlob(1);byte[]bdata=blob.getBytes(1,(int)blob.length()); 最佳答案 你的意思是你想要获取blob存储内容的文件的扩展名?因此,如果BLOB存储jpeg文件的内容,您需要"jpg"?一般来说这是不可能的。您可以使用一些启发式方法(例如ApacheTikascontentdetection)做出相当不错的猜测。.但是,更好的解决方案是
为什么charc=(char)65.8;允许在Java中使用?因为65.8不是一个确切的Unicode值,它不应该抛出错误吗?我知道double被截断为整数,在本例中为65,但在我看来允许程序员进行这样的转换似乎是糟糕的设计。 最佳答案 这就是所谓的缩小类型转换。来自oracledocs:22specificconversionsonprimitivetypesarecalledthenarrowingprimitiveconversions:shorttobyteorcharchartobyteorshortinttobyte,s
当一个java.lang.Double对象在没有调用构造函数而是使用原语的情况下被初始化时会发生什么?它似乎有效,但我不太确定为什么。编译器是否正在进行某种隐式转换?这是使用Java5。publicclassFoo{publicstaticvoidmain(String[]args){Doubled=5.1;System.out.println(d.toString());}} 最佳答案 这叫做Autoboxing这是Java5中添加的一个特性。它会自动在基本类型和包装类型之间进行转换,例如double(基本类型)和java.lan
一个可能很蹩脚的快速问题。在下面的代码中:MapdataMap=newMap();dataMap.put(1,newDouble[]{100,100});Double[]dob=dataMap.get(1);dob[0]=100;dob[1]=200;dataMap.put(1,dob);是否需要最后的“dataMap.put”指令?或者dataMap.get(1)会产生对数组的引用,然后在后面的语句中直接修改该数组。我知道,在可变对象(例如Map)的情况下,Map.get()会给我所需对象的引用,但是有一个Double数组(其元素类型例如Double是不可变的)我不确定我是否得到了对