在相关的源代码中可以看到,该值将被修剪:
static FloatingDecimal.ASCIIToBinaryConverter readJavaFormatString(String arg) throws NumberFormatException {
boolean arg0 = false;
boolean arg1 = false;
try {
arg = arg.trim();
....
因此,在转换为floatValue之前将删除空格.
有关更多信息,请参见Float.class调用的FloatingDecimal源代码.
Integer.parseInt()不会修剪字符串值:
public static int parseInt(String arg, int arg0) throws NumberFormatException {
if (arg == null) {
throw new NumberFormatException("null");
} else if (arg0 < 2) {
throw new NumberFormatException("radix " + arg0 + " less than Character.MIN_RADIX");
} else if (arg0 > 36) {
throw new NumberFormatException("radix " + arg0 + " greater than Character.MAX_RADIX");
} else {
int arg1 = 0;
boolean arg2 = false;
int arg3 = 0;
int arg4 = arg.length();
int arg5 = -2147483647;
if (arg4 > 0) {
char arg8 = arg.charAt(0);
if (arg8 < 48) {
if (arg8 == 45) {
arg2 = true;
arg5 = MIN_VALUE;
} else if (arg8 != 43) {
throw NumberFormatException.forInputString(arg);
}
if (arg4 == 1) {
throw NumberFormatException.forInputString(arg);
}
++arg3;
}
int arg7;
for (int arg6 = arg5 / arg0; arg3 < arg4; arg1 -= arg7) {
arg7 = Character.digit(arg.charAt(arg3++), arg0);
if (arg7 < 0) {
throw NumberFormatException.forInputString(arg);
}
if (arg1 < arg6) {
throw NumberFormatException.forInputString(arg);
}
arg1 *= arg0;
if (arg1 < arg5 + arg7) {
throw NumberFormatException.forInputString(arg);
}
}
return arg2 ? arg1 : -arg1;
} else {
throw NumberFormatException.forInputString(arg);
}
}
}
那就是为什么你在那里得到一个例外