所以我目前正在开发一个将IEEE-754单精度和双精度浮点数转换为十进制数的程序。该程序抛出了 java.lang.NumberFormatException 。我希望有人向我解释为什么会抛出它以及我应该如何修复它。
//This is the method being used for the IEEE-754 double-precision to decimal
//line 5 is where the error is thrown
1 double deciFinal;
2 System.out.println("What IEEE-754 double precision floating-point representsation will you like to input?");
3 ieee754 = input.nextLine();
4 ieee754 = ieee754.trim();
5 deciFinal = Double.longBitsToDouble(Long.parseLong(ieee754,2));
6 System.out.println(deciFinal);
//This is the method being used for the IEEE-754 single-precision to decimal
//Line 5 is also where the error is being thrown.
1 int binIeee;
2 float deciFinal;
3 System.out.println("What IEEE-754 single precision floating-point representsation will you like to input?");
4 ieee754 = input.nextLine();
5 deciFinal = Float.intBitsToFloat(Integer.parseInt(ieee754, 2));
6 System.out.println(deciFinal);
如果您想引用它以帮助我自己了解更多
,这是我的完整代码import java.util.Scanner;
/**
*
* @author Edwin
*/
public class DecimalToIEE754 {
public static void main(String[]args){
int choice;
Scanner input = new Scanner(System.in);
do{
double deciNum;
String ieee754 = " ";
int bitsVal;
String bitsString;
System.out.println("Hello Welcome to the Decimal and IEEE-754 converter");
System.out.println("Please select the number that correspondes with the conversion you will like:"
+ "\n 1) Convert decimal number to IEEE-754 Single Precision Floating-Point Representation"
+ "\n 2) Convert decimal number to IEEE-754 Double Precision Floating-Point Representation"
+ "\n 3) Convert IEEE-754 Single Precision Floating-Point Representation to decimal number"
+ "\n 4) Convert IEEE-754 Double Precision Floating-Point Representation to decimal number "
+ "\n 0) Exit Converter");
choice = input.nextInt();
if(choice == 1)
{
System.out.println("What decimal number will you like to convert?");
deciNum = input.nextDouble();
float f = (float)deciNum;
bitsVal = Float.floatToIntBits(f);
bitsString = Integer.toBinaryString(bitsVal);
System.out.println(bitsString);
}
if(choice == 2)
{
System.out.println("What decimal number will you like to convert?");
deciNum = input.nextDouble();
bitsString = Long.toString(Double.doubleToLongBits(deciNum), 2);
System.out.println(bitsString);
}
if(choice == 3)
{
int binIeee;
float deciFinal;
System.out.println("What IEEE-754 single precision floating-point representsation will you like to input?");
ieee754 = input.nextLine();
**deciFinal = Float.intBitsToFloat(Integer.parseInt(ieee754, 2));**
System.out.println(deciFinal);
}
if(choice == 4)
{
double deciFinal;
System.out.println("What IEEE-754 double precision floating-point representsation will you like to input?");
ieee754 = input.nextLine();
ieee754 = ieee754.trim();
**deciFinal = Double.longBitsToDouble(Long.parseLong(ieee754,2));**
System.out.println(deciFinal);
}
}while (choice != 0);
}
}
一旦我为Ieee-754输入3或4转换为十进制,就会出现错误。它不允许我输入Ieee-754号码。完整的错误是:
Exception in thread "main" java.lang.NumberFormatException: For input string: ""
at java.lang.NumberFormatException.forInputString(NumberFormatException.java:65)
at java.lang.Integer.parseInt(Integer.java:504)
at DecimalToIEE754.main(DecimalToIEE754.java:53)
Java Result: 1
答案 0 :(得分:1)
致电时
Scanner.nextInt();
接着是
Scanner.nextLine();
表示nextLine()
将读取该数字后面的其余部分。您可能没有在数字后输入任何内容,因此nextLine返回空字符串“”,您可以在抛出的异常中看到它。
解决这个问题的简单方法是致电
int option = scanner.nextInt();
scanner.nextLine(); // ignore the rest of the line.
// now reads the next line
String line = scanner.nextLine();
很可能你有一个负数。如果你有一个数字(最高位设置为1)10101010 ... 1010101并且是32位长,这太大了,不能存储在32位签名 int中。您可以将其解析为Long并将其转换为(int)
尝试将64位二进制文件解析为Long时遇到同样的问题。在这种情况下,您必须使用BigInteger并将其强制转换为long,或编写自己的解析器。
答案 1 :(得分:0)
您的问题出在此处:choice = input.nextInt();
nextInt
使用int
,但不使用换行符。因此,下次您致电nextLine
时,您会收到一个空字符串,因为该行上的所有内容都已被使用=>您需要添加nextLine
:
choice = input.nextInt();
nextLine();
//go on with your code
同样适用于nextDouble
。