无法重现NumberFormatException

时间:2012-11-30 18:05:09

标签: android numberformatexception

最近我发布了我的Android应用(GitHubRepo)的更新,我开始通过Play商店从用户那里收到错误报告。我正在尝试进行故障排除,但我无法准确追踪错误的含义。

以下是报告的内容:

java.lang.RuntimeException: Unable to start activity ComponentInfo{ca.ajwest.BeerConverter/ca.ajwest.BeerConverter.BeerConverterActivity}: java.lang.NumberFormatException
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1651)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1667)
at android.app.ActivityThread.access$1500(ActivityThread.java:117)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:935)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:130)
at android.app.ActivityThread.main(ActivityThread.java:3687)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:507)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:625)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NumberFormatException
at org.apache.harmony.luni.util.FloatingPointParser.parseDblImpl(Native Method)
at org.apache.harmony.luni.util.FloatingPointParser.parseDouble(FloatingPointParser.java:283)
at java.lang.Double.parseDouble(Double.java:318)
at java.lang.Double.valueOf(Double.java:356)
at ca.ajwest.BeerConverter.BeerConverterActivity.roundTwoDecimals(BeerConverterActivity.java:1513)
at ca.ajwest.BeerConverter.BeerConverterActivity.calculate(BeerConverterActivity.java:987)
at ca.ajwest.BeerConverter.BeerConverterActivity.access$0(BeerConverterActivity.java:757)
at ca.ajwest.BeerConverter.BeerConverterActivity$21.onTextChanged(BeerConverterActivity.java:469)
at android.widget.TextView.sendOnTextChanged(TextView.java:6584)
at android.widget.TextView.setText(TextView.java:2813)
at android.widget.TextView.setText(TextView.java:2671)
at android.widget.EditText.setText(EditText.java:178)
at ca.ajwest.BeerConverter.BeerConverterActivity.onCreate(BeerConverterActivity.java:541)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1615)
... 11 more

我是否正确地假设它与我的舍入方法舍入的值有关?

double roundTwoDecimals(double d){
        DecimalFormat twoDForm = new DecimalFormat("#.##");
        return Double.valueOf(twoDForm.format(d));
    }

当我无法在设备上重现错误时,有没有人有任何关于如何继续的提示?该应用程序在很大程度上依赖于输入数字的用户,甚至在我的字段中尝试各种“杂乱”数字后(我已经尝试了一些非常长的数字),它对我来说完美无瑕。

1 个答案:

答案 0 :(得分:1)

您可能没有考虑用户区域设置。许多语言环境使用逗号分隔符。

这将强制您的格式化程序使用一个点作为分隔符。

double roundTwoDecimals(double d){

    DecimalFormat twoDForm = new DecimalFormat("#.##");
    DecimalFormatSymbols dfSymbols = new DecimalFormatSymbols();
    twoDForm.setDecimalSeparator('.');
    format.setDecimalFormatSymbols(dfSymbols);

    return Double.valueOf(twoDForm.format(d));
}

如果您的用户手动输入数字,您可以获取区域设置分隔符并使用它。

DecimalFormat.getInstance().getDecimalFormatSymbols().getDecimalSeparator();

PS。你的假设是正确的。通常,读取堆栈跟踪,直到从应用程序中看到包名称。这指向违规行,在这种情况下:

ca.ajwest.BeerConverter.BeerConverterActivity.roundTwoDecimals(BeerConverterActivity.java:1513)