我在我的 Android 应用程序中遇到问题,当我尝试保存值时我的应用程序崩溃。我正在制作一个在线货币转换器。这是我的代码的一部分:
View.OnClickListener myhandler1 = new View.OnClickListener() {
@Override
public void onClick(View v) {
String text1 = spinner1.getSelectedItem().toString().trim();
String text2 = spinner2.getSelectedItem().toString().trim();
if (text1.equals("US Dollar - USD") && text2.equals("Euro - EUR") && edittextdollars.length() > 0 && edittexteuros.length()==0) {
try {
convertvalues("USD", "EUR");
float k = Float.parseFloat(convertvalues("USD", "EUR"));
SharedPreferences settings = getActivity().getSharedPreferences("Pref", 0);
SharedPreferences.Editor editor = settings.edit();
editor.putFloat("dollarseuros", k);
editor.commit();
}
catch (Exception e) {
SharedPreferences settings = getActivity().getSharedPreferences("Pref", 0);
float val = Float.parseFloat(edittextdollars.getText().toString());
float k = Float.parseFloat(convertvalues("USD", "EUR"));
DecimalFormat df = new DecimalFormat(".##");
String l = df.format(k * val);
edittexteuros.setText(settings.getString("dollarseuros", l));
}
}
我的应用程序应该做的是获取美元兑欧元汇率的价值,然后将其保存到没有互联网连接为止。当没有可用的互联网连接时,它应该使用缓存的值。
这是我的 LogCat:
07-24 00:16:14.804: E/AndroidRuntime(1298): FATAL EXCEPTION: main
07-24 00:16:14.804: E/AndroidRuntime(1298): java.lang.NumberFormatException: Invalid float: ""
07-24 00:16:14.804: E/AndroidRuntime(1298): at java.lang.StringToReal.invalidReal(StringToReal.java:63)
07-24 00:16:14.804: E/AndroidRuntime(1298): at java.lang.StringToReal.parseFloat(StringToReal.java:289)
07-24 00:16:14.804: E/AndroidRuntime(1298): at java.lang.Float.parseFloat(Float.java:300)
07-24 00:16:14.804: E/AndroidRuntime(1298): at com.example.currencyconverter.MainActivity$1.onClick(MainActivity.java:240)
07-24 00:16:14.804: E/AndroidRuntime(1298): at android.view.View.performClick(View.java:4204)
07-24 00:16:14.804: E/AndroidRuntime(1298): at android.view.View$PerformClick.run(View.java:17355)
07-24 00:16:14.804: E/AndroidRuntime(1298): at android.os.Handler.handleCallback(Handler.java:725)
07-24 00:16:14.804: E/AndroidRuntime(1298): at android.os.Handler.dispatchMessage(Handler.java:92)
07-24 00:16:14.804: E/AndroidRuntime(1298): at android.os.Looper.loop(Looper.java:137)
07-24 00:16:14.804: E/AndroidRuntime(1298): at android.app.ActivityThread.main(ActivityThread.java:5041)
07-24 00:16:14.804: E/AndroidRuntime(1298): at java.lang.reflect.Method.invokeNative(Native Method)
07-24 00:16:14.804: E/AndroidRuntime(1298): at java.lang.reflect.Method.invoke(Method.java:511)
07-24 00:16:14.804: E/AndroidRuntime(1298): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
07-24 00:16:14.804: E/AndroidRuntime(1298): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
07-24 00:16:14.804: E/AndroidRuntime(1298): at dalvik.system.NativeStart.main(Native Method)
怎么了?我已经检查了 Google 和 StackOverflow,但没有解决我的问题。任何帮助将不胜感激。