Android 如果作为应用程序安装,应用程序会崩溃,如果通过 Android Studio 运行则可以正常工作
Android app crashes if installed as apk, works if runned trough Android Studio
我在 Android Studio 2.1.3 中制作了一个应用程序,当然我已经在(不同的)模拟器和我自己的 phone(小米 Redmi Note 3,Android 5.0.2 LRX22G)。当我把应用程序交给几个朋友测试时,他们都说了同样的话:应用程序正常启动,他们 select 他们感兴趣的 activity,他们在文本字段中输入数据,然后当他们按下按钮(应该做一些数学运算)来接收数学答案时,应用程序停止并且 returns 到 "main" activity.
compileSdkVersion 24
buildToolsVersion '23.0.3'
dexOptions { javaMaxHeapSize "4g" }
defaultConfig { applicationId "com.example.android.rechner" minSdkVersion 17
targetSdkVersion 24
versionCode 4
versionName 'v.1.6.0 - Entwickler Stufe V.16.9.03'
multiDexEnabled true
我买了一台平板电脑,希望能将同样的崩溃连接到 android studio 并有机会进行调试。我通过 BT 将 apk(调试 apk,而不是发布)发送到平板电脑(Teclast Tpad X80 Pro(E3E7),Android 5.1),安装了应用程序,并按预期工作!
现在我生气了! :)
我去找另一个朋友做了与平板电脑相同的事情,但将文件发送到三星 Galaxy Grand Prime(没看 android 版本有什么),当我尝试做数学时崩溃!他给了我一台三星 Galaxy S3 Mini(GT-I8200N,Android 4.2.2),我通过 BT 发送 APK,同样的事情发生了!
好吧,我开始开心了,因为我带着 phone,我启用开发者选项,通过 USB 调试,将 phone 连接到我的电脑,加载应用程序Android 工作室,你猜怎么着?!它可以正常工作,没有任何错误、crases 或任何东西!
我将 phone 重置为出厂设置,希望强制错误...我通过 BT 发送文件,并且...它有效!没有任何错误或崩溃,尽管在重置后 phone 没有连接到我的计算机(和 Android Studio)。我没有看到问题,也无法在调试日志中寻找答案,因为连接到 PC 不会失败:(
我需要说明的是,我在其他 phone 上启用了开发人员选项我已经测试了该应用程序,但唯一的区别是 none 已连接到我的计算机并且 Android工作室!
你们以前遇到过这个问题吗?我在 google 朋友那里搜索了几天类似的东西,但没有找到任何东西。
感谢您的耐心解答!
此致,罗伯特 P.
L.E。我刷新了 phone,删除了缓存和数据,重新安装了 apk,最后崩溃了。我成功读取了 adb logcat :
W/dalvikvm( 4700): threadid=1: thread exiting with uncaught exception (group=0x40d7d960)
E/AndroidRuntime( 4700): FATAL EXCEPTION: main
E/AndroidRuntime( 4700): java.lang.StringIndexOutOfBoundsException: length=4; regionStart=0; regionLength=-1
E/AndroidRuntime( 4700): at java.lang.String.startEndAndLength(String.java:583)
E/AndroidRuntime( 4700): at java.lang.String.substring(String.java:1464)
E/AndroidRuntime( 4700): at com.example.android.rechner.MainActivityRustZ.displayTimeReal(MainActivityRustZ.java:109)
E/AndroidRuntime( 4700): at com.example.android.rechner.MainActivityRustZ.access0(MainActivityRustZ.java:12)
E/AndroidRuntime( 4700): at com.example.android.rechner.MainActivityRustZ.onClick(MainActivityRustZ.java:29)
E/AndroidRuntime( 4700): at android.view.View.performClick(View.java:4452)
E/AndroidRuntime( 4700): at android.widget.Button.performClick(Button.java:148)
E/AndroidRuntime( 4700): at android.view.View$PerformClick.run(View.java:18428)
E/AndroidRuntime( 4700): at android.os.Handler.handleCallback(Handler.java:725)
E/AndroidRuntime( 4700): at android.os.Handler.dispatchMessage(Handler.java:92)
E/AndroidRuntime( 4700): at android.os.Looper.loop(Looper.java:176)
E/AndroidRuntime( 4700): at android.app.ActivityThread.main(ActivityThread.java:5365)
E/AndroidRuntime( 4700): at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime( 4700): at java.lang.reflect.Method.invoke(Method.java:511)
E/AndroidRuntime( 4700): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)
E/AndroidRuntime( 4700): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)
E/AndroidRuntime( 4700): at dalvik.system.NativeStart.main(Native Method)
现在,第 109 行:
字符串 unitatiTimpReal = formattedTimpR.substring(0, formattedTimpR.indexOf(".")); //单位
属于:
private void displayTimeReal(double timpreal) {
Double vZeitD = Double.parseDouble(((EditText) findViewById(R.id.vZeit)).getText().toString());
Double aufStZahl = Double.parseDouble(((EditText) findViewById(R.id.aufGesSt)).getText().toString());
timpreal = aufStZahl / ((procente / vZeitD) * mitarbeiter);
DecimalFormat formattr = new DecimalFormat();
formattr.setMaximumFractionDigits(2);
formattr.setMinimumFractionDigits(2);
String formattedTimpR = formattr.format(timpreal);
String zecimaleTimpReal = formattedTimpR.substring(formattedTimpR.indexOf(".") + 1); //decimals
String unitatiTimpReal = formattedTimpR.substring(0, formattedTimpR.indexOf(".")); //unit
double minutereal = Double.parseDouble(zecimaleTimpReal);
minutereal = minutereal * 0.6;
DecimalFormat format = new DecimalFormat();
format.setMaximumFractionDigits(2);
String formattedMinuteReal = format.format(minutereal);
TextView timeTextView = (TextView) findViewById(R.id.rezultat_ore_real);
timeTextView.setText(getString(R.string.slaufz) + unitatiTimpReal + getString(R.string.shours) + formattedMinuteReal + getString(R.string.sminutes));
}
现在,相同的线路在那里,相同的操作在那里,相同的 apk ...但是如果我 运行 应用程序只通过 Android Studio 一次,直到一个完整的固件重写和缓存删除,应用程序将 运行ning 而不会崩溃!
按照建议更新后:
这一行:
String unitatiTimpReal = formattedTimpR.substring(0, formattedTimpR.indexOf(".")); //unit
进入:
String unitatiTimpReal;
int index = formattedTimpR.indexOf(".");
if(index != -1) {
unitatiTimpReal = formattedTimpR.substring(0, index);
} else {
// formattedTimpR does not contain ".", handle this somehow
unitatiTimpReal = "";
}
我明白了:
W/dalvikvm( 3518): threadid=1: thread exiting with uncaught exception (group=0x40cf4960)
E/AndroidRuntime( 3518): FATAL EXCEPTION: main
E/AndroidRuntime( 3518): java.lang.NumberFormatException: Invalid double: "3,32"
E/AndroidRuntime( 3518): at java.lang.StringToReal.invalidReal(StringToReal.java:63)
E/AndroidRuntime( 3518): at java.lang.StringToReal.parseDouble(StringToReal.java:269)
E/AndroidRuntime( 3518): at java.lang.Double.parseDouble(Double.java:295)
E/AndroidRuntime( 3518): at com.example.android.rechner.MainActivityRustZ.displayTimeReal(MainActivityRustZ.java:118)
E/AndroidRuntime( 3518): at com.example.android.rechner.MainActivityRustZ.access0(MainActivityRustZ.java:12)
E/AndroidRuntime( 3518): at com.example.android.rechner.MainActivityRustZ.onClick(MainActivityRustZ.java:29)
E/AndroidRuntime( 3518): at android.view.View.performClick(View.java:4452)
E/AndroidRuntime( 3518): at android.widget.Button.performClick(Button.java:148)
E/AndroidRuntime( 3518): at android.view.View$PerformClick.run(View.java:18428)
E/AndroidRuntime( 3518): at android.os.Handler.handleCallback(Handler.java:725)
E/AndroidRuntime( 3518): at android.os.Handler.dispatchMessage(Handler.java:92)
E/AndroidRuntime( 3518): at android.os.Looper.loop(Looper.java:176)
E/AndroidRuntime( 3518): at android.app.ActivityThread.main(ActivityThread.java:5365)
E/AndroidRuntime( 3518): at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime( 3518): at java.lang.reflect.Method.invoke(Method.java:511)
E/AndroidRuntime( 3518): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)
E/AndroidRuntime( 3518): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)
E/AndroidRuntime( 3518): at dalvik.system.NativeStart.main(Native Method)
第 118 行是:
double minutereal = Double.parseDouble(zecimaleTimpReal);
@user13
我想要实现的目标:
在我为用户做的一些其他计算中,根据它输入的数据,我实时转换工业时间(以分钟、小时为单位的时间(更准确地说是 60 分钟正常时间中的 100 分钟工业时间)
private void displayTimeReal(double timpreal) {
将 var vZeitD 初始化为 double,要求用户输入数学运算
Double vZeitD = Double.parseDouble(((EditText) findViewById(R.id.vZeit)).getText().toString());
将 var aufStZahl 初始化为 double,要求用户输入数学运算 - 这里我可以修改为整数,因为只允许输入整数
Double aufStZahl = Double.parseDouble(((EditText) findViewById(R.id.aufGesSt)).getText().toString());
显示所需时间的数学运算(但采用工业时间,即 100 分钟)
timpreal = aufStZahl / ((procente / vZeitD) * mitarbeiter);
我将答案分开(例如 12.75,其中 12 是小时,75 是分钟)并且我设置了最大和最小显示的小数位数 (2) :
DecimalFormat formattr = new DecimalFormat();
formattr.setMaximumFractionDigits(2);
formattr.setMinimumFractionDigits(2);
String formattedTimpR = formattr.format(timpreal);
从工业中提取小数
String zecimaleTimpReal = formattedTimpR.substring(formattedTimpR.indexOf(".") + 1); //decimals
计算完成后从结果数字中取出单位(单位仍按原样显示
String unitatiTimpReal = formattedTimpR.substring(0, formattedTimpR.indexOf(".")); //unit
因为我又得做数学,所以我不能使用字符串,我将小数转换为双精度,然后转换为实时(60 分钟)
double minutereal = Double.parseDouble(zecimaleTimpReal);
minutereal = minutereal * 0.6;
我再次设置了分钟的最大小数位数(这样我就不会显示像 39.326562365 这样的响应)(例如:39.33 分钟而不是 39.326562365)
DecimalFormat format = new DecimalFormat();
format.setMaximumFractionDigits(2);
String formattedMinuteReal = format.format(minutereal);
向用户显示结果:
TextView timeTextView = (TextView) findViewById(R.id.rezultat_ore_real);
timeTextView.setText(getString(R.string.slaufz) + unitatiTimpReal + getString(R.string.shours) + formattedMinuteReal + getString(R.string.sminutes));
}
问题是第109行formattedTimpR
不包含字符串"."
.
正因为如此,indexOf()
方法 returns -1
,所以基本上你在调用 substring(0, -1)
,因此出现错误。
我真的不知道你想要什么,但你至少可以在调用 substring()
之前做一个检查,像这样:
String unitatiTimpReal;
int index = formattedTimpR.indexOf(".");
if(index != -1) {
unitatiTimpReal = formattedTimpR.substring(0, index);
} else {
// formattedTimpR does not contain ".", handle this somehow
unitatiTimpReal = "";
}
问题似乎是由于设备 Locale 的数字格式不同造成的。
当您使用 DecimalFormat 对象时,小数点分隔符因设备的语言设置而异。例如在英语中它是一个点,例如3.14159
但在德语中是逗号,例如3,14159
.
这会导致问题,因为当您调用 indexOf() 时,您的代码总是在寻找一个点。
您可以通过多种方式解决此问题。一种方法是在创建 DecimalFormat 对象时指定语言环境,例如:
NumberFormat nf = NumberFormat.getNumberInstance(Locale.ENGLISH);
DecimalFormat formattr = (DecimalFormat)nf;
否则你可以只设置小数点分隔符:
DecimalFormat formattr = new DecimalFormat();
formattr.setDecimalSeparator('.');
但是您可能希望它对德国用户显示不同。在这种情况下,您可以更改检查点的代码以检查正确的字符是什么:
String zecimaleTimpReal = formattedTimpR.substring(formattedTimpR.indexOf("" + formattr.getDecimalFormatSymbols().getDecimalSeparator()) + 1);
添加到空字符串只是将 char 转换为 String 的技巧。
请注意,还有一个 "grouping symbol",它也可以是逗号或点,例如123,456.78
。您可能想要禁用分组,如下所示:
formattr.setGroupingUsed(false);
我在 Android Studio 2.1.3 中制作了一个应用程序,当然我已经在(不同的)模拟器和我自己的 phone(小米 Redmi Note 3,Android 5.0.2 LRX22G)。当我把应用程序交给几个朋友测试时,他们都说了同样的话:应用程序正常启动,他们 select 他们感兴趣的 activity,他们在文本字段中输入数据,然后当他们按下按钮(应该做一些数学运算)来接收数学答案时,应用程序停止并且 returns 到 "main" activity.
compileSdkVersion 24
buildToolsVersion '23.0.3'
dexOptions { javaMaxHeapSize "4g" }
defaultConfig { applicationId "com.example.android.rechner" minSdkVersion 17
targetSdkVersion 24
versionCode 4
versionName 'v.1.6.0 - Entwickler Stufe V.16.9.03'
multiDexEnabled true
我买了一台平板电脑,希望能将同样的崩溃连接到 android studio 并有机会进行调试。我通过 BT 将 apk(调试 apk,而不是发布)发送到平板电脑(Teclast Tpad X80 Pro(E3E7),Android 5.1),安装了应用程序,并按预期工作! 现在我生气了! :) 我去找另一个朋友做了与平板电脑相同的事情,但将文件发送到三星 Galaxy Grand Prime(没看 android 版本有什么),当我尝试做数学时崩溃!他给了我一台三星 Galaxy S3 Mini(GT-I8200N,Android 4.2.2),我通过 BT 发送 APK,同样的事情发生了!
好吧,我开始开心了,因为我带着 phone,我启用开发者选项,通过 USB 调试,将 phone 连接到我的电脑,加载应用程序Android 工作室,你猜怎么着?!它可以正常工作,没有任何错误、crases 或任何东西! 我将 phone 重置为出厂设置,希望强制错误...我通过 BT 发送文件,并且...它有效!没有任何错误或崩溃,尽管在重置后 phone 没有连接到我的计算机(和 Android Studio)。我没有看到问题,也无法在调试日志中寻找答案,因为连接到 PC 不会失败:(
我需要说明的是,我在其他 phone 上启用了开发人员选项我已经测试了该应用程序,但唯一的区别是 none 已连接到我的计算机并且 Android工作室!
你们以前遇到过这个问题吗?我在 google 朋友那里搜索了几天类似的东西,但没有找到任何东西。
感谢您的耐心解答!
此致,罗伯特 P.
L.E。我刷新了 phone,删除了缓存和数据,重新安装了 apk,最后崩溃了。我成功读取了 adb logcat :
W/dalvikvm( 4700): threadid=1: thread exiting with uncaught exception (group=0x40d7d960)
E/AndroidRuntime( 4700): FATAL EXCEPTION: main
E/AndroidRuntime( 4700): java.lang.StringIndexOutOfBoundsException: length=4; regionStart=0; regionLength=-1
E/AndroidRuntime( 4700): at java.lang.String.startEndAndLength(String.java:583)
E/AndroidRuntime( 4700): at java.lang.String.substring(String.java:1464)
E/AndroidRuntime( 4700): at com.example.android.rechner.MainActivityRustZ.displayTimeReal(MainActivityRustZ.java:109)
E/AndroidRuntime( 4700): at com.example.android.rechner.MainActivityRustZ.access0(MainActivityRustZ.java:12)
E/AndroidRuntime( 4700): at com.example.android.rechner.MainActivityRustZ.onClick(MainActivityRustZ.java:29)
E/AndroidRuntime( 4700): at android.view.View.performClick(View.java:4452)
E/AndroidRuntime( 4700): at android.widget.Button.performClick(Button.java:148)
E/AndroidRuntime( 4700): at android.view.View$PerformClick.run(View.java:18428)
E/AndroidRuntime( 4700): at android.os.Handler.handleCallback(Handler.java:725)
E/AndroidRuntime( 4700): at android.os.Handler.dispatchMessage(Handler.java:92)
E/AndroidRuntime( 4700): at android.os.Looper.loop(Looper.java:176)
E/AndroidRuntime( 4700): at android.app.ActivityThread.main(ActivityThread.java:5365)
E/AndroidRuntime( 4700): at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime( 4700): at java.lang.reflect.Method.invoke(Method.java:511)
E/AndroidRuntime( 4700): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)
E/AndroidRuntime( 4700): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)
E/AndroidRuntime( 4700): at dalvik.system.NativeStart.main(Native Method)
现在,第 109 行: 字符串 unitatiTimpReal = formattedTimpR.substring(0, formattedTimpR.indexOf(".")); //单位
属于:
private void displayTimeReal(double timpreal) {
Double vZeitD = Double.parseDouble(((EditText) findViewById(R.id.vZeit)).getText().toString());
Double aufStZahl = Double.parseDouble(((EditText) findViewById(R.id.aufGesSt)).getText().toString());
timpreal = aufStZahl / ((procente / vZeitD) * mitarbeiter);
DecimalFormat formattr = new DecimalFormat();
formattr.setMaximumFractionDigits(2);
formattr.setMinimumFractionDigits(2);
String formattedTimpR = formattr.format(timpreal);
String zecimaleTimpReal = formattedTimpR.substring(formattedTimpR.indexOf(".") + 1); //decimals
String unitatiTimpReal = formattedTimpR.substring(0, formattedTimpR.indexOf(".")); //unit
double minutereal = Double.parseDouble(zecimaleTimpReal);
minutereal = minutereal * 0.6;
DecimalFormat format = new DecimalFormat();
format.setMaximumFractionDigits(2);
String formattedMinuteReal = format.format(minutereal);
TextView timeTextView = (TextView) findViewById(R.id.rezultat_ore_real);
timeTextView.setText(getString(R.string.slaufz) + unitatiTimpReal + getString(R.string.shours) + formattedMinuteReal + getString(R.string.sminutes));
}
现在,相同的线路在那里,相同的操作在那里,相同的 apk ...但是如果我 运行 应用程序只通过 Android Studio 一次,直到一个完整的固件重写和缓存删除,应用程序将 运行ning 而不会崩溃!
按照建议更新后: 这一行:
String unitatiTimpReal = formattedTimpR.substring(0, formattedTimpR.indexOf(".")); //unit
进入:
String unitatiTimpReal;
int index = formattedTimpR.indexOf(".");
if(index != -1) {
unitatiTimpReal = formattedTimpR.substring(0, index);
} else {
// formattedTimpR does not contain ".", handle this somehow
unitatiTimpReal = "";
}
我明白了:
W/dalvikvm( 3518): threadid=1: thread exiting with uncaught exception (group=0x40cf4960)
E/AndroidRuntime( 3518): FATAL EXCEPTION: main
E/AndroidRuntime( 3518): java.lang.NumberFormatException: Invalid double: "3,32"
E/AndroidRuntime( 3518): at java.lang.StringToReal.invalidReal(StringToReal.java:63)
E/AndroidRuntime( 3518): at java.lang.StringToReal.parseDouble(StringToReal.java:269)
E/AndroidRuntime( 3518): at java.lang.Double.parseDouble(Double.java:295)
E/AndroidRuntime( 3518): at com.example.android.rechner.MainActivityRustZ.displayTimeReal(MainActivityRustZ.java:118)
E/AndroidRuntime( 3518): at com.example.android.rechner.MainActivityRustZ.access0(MainActivityRustZ.java:12)
E/AndroidRuntime( 3518): at com.example.android.rechner.MainActivityRustZ.onClick(MainActivityRustZ.java:29)
E/AndroidRuntime( 3518): at android.view.View.performClick(View.java:4452)
E/AndroidRuntime( 3518): at android.widget.Button.performClick(Button.java:148)
E/AndroidRuntime( 3518): at android.view.View$PerformClick.run(View.java:18428)
E/AndroidRuntime( 3518): at android.os.Handler.handleCallback(Handler.java:725)
E/AndroidRuntime( 3518): at android.os.Handler.dispatchMessage(Handler.java:92)
E/AndroidRuntime( 3518): at android.os.Looper.loop(Looper.java:176)
E/AndroidRuntime( 3518): at android.app.ActivityThread.main(ActivityThread.java:5365)
E/AndroidRuntime( 3518): at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime( 3518): at java.lang.reflect.Method.invoke(Method.java:511)
E/AndroidRuntime( 3518): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)
E/AndroidRuntime( 3518): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)
E/AndroidRuntime( 3518): at dalvik.system.NativeStart.main(Native Method)
第 118 行是:
double minutereal = Double.parseDouble(zecimaleTimpReal);
@user13 我想要实现的目标: 在我为用户做的一些其他计算中,根据它输入的数据,我实时转换工业时间(以分钟、小时为单位的时间(更准确地说是 60 分钟正常时间中的 100 分钟工业时间)
private void displayTimeReal(double timpreal) {
将 var vZeitD 初始化为 double,要求用户输入数学运算
Double vZeitD = Double.parseDouble(((EditText) findViewById(R.id.vZeit)).getText().toString());
将 var aufStZahl 初始化为 double,要求用户输入数学运算 - 这里我可以修改为整数,因为只允许输入整数
Double aufStZahl = Double.parseDouble(((EditText) findViewById(R.id.aufGesSt)).getText().toString());
显示所需时间的数学运算(但采用工业时间,即 100 分钟)
timpreal = aufStZahl / ((procente / vZeitD) * mitarbeiter);
我将答案分开(例如 12.75,其中 12 是小时,75 是分钟)并且我设置了最大和最小显示的小数位数 (2) :
DecimalFormat formattr = new DecimalFormat();
formattr.setMaximumFractionDigits(2);
formattr.setMinimumFractionDigits(2);
String formattedTimpR = formattr.format(timpreal);
从工业中提取小数
String zecimaleTimpReal = formattedTimpR.substring(formattedTimpR.indexOf(".") + 1); //decimals
计算完成后从结果数字中取出单位(单位仍按原样显示
String unitatiTimpReal = formattedTimpR.substring(0, formattedTimpR.indexOf(".")); //unit
因为我又得做数学,所以我不能使用字符串,我将小数转换为双精度,然后转换为实时(60 分钟)
double minutereal = Double.parseDouble(zecimaleTimpReal);
minutereal = minutereal * 0.6;
我再次设置了分钟的最大小数位数(这样我就不会显示像 39.326562365 这样的响应)(例如:39.33 分钟而不是 39.326562365)
DecimalFormat format = new DecimalFormat();
format.setMaximumFractionDigits(2);
String formattedMinuteReal = format.format(minutereal);
向用户显示结果:
TextView timeTextView = (TextView) findViewById(R.id.rezultat_ore_real);
timeTextView.setText(getString(R.string.slaufz) + unitatiTimpReal + getString(R.string.shours) + formattedMinuteReal + getString(R.string.sminutes));
}
问题是第109行formattedTimpR
不包含字符串"."
.
正因为如此,indexOf()
方法 returns -1
,所以基本上你在调用 substring(0, -1)
,因此出现错误。
我真的不知道你想要什么,但你至少可以在调用 substring()
之前做一个检查,像这样:
String unitatiTimpReal;
int index = formattedTimpR.indexOf(".");
if(index != -1) {
unitatiTimpReal = formattedTimpR.substring(0, index);
} else {
// formattedTimpR does not contain ".", handle this somehow
unitatiTimpReal = "";
}
问题似乎是由于设备 Locale 的数字格式不同造成的。
当您使用 DecimalFormat 对象时,小数点分隔符因设备的语言设置而异。例如在英语中它是一个点,例如3.14159
但在德语中是逗号,例如3,14159
.
这会导致问题,因为当您调用 indexOf() 时,您的代码总是在寻找一个点。
您可以通过多种方式解决此问题。一种方法是在创建 DecimalFormat 对象时指定语言环境,例如:
NumberFormat nf = NumberFormat.getNumberInstance(Locale.ENGLISH);
DecimalFormat formattr = (DecimalFormat)nf;
否则你可以只设置小数点分隔符:
DecimalFormat formattr = new DecimalFormat();
formattr.setDecimalSeparator('.');
但是您可能希望它对德国用户显示不同。在这种情况下,您可以更改检查点的代码以检查正确的字符是什么:
String zecimaleTimpReal = formattedTimpR.substring(formattedTimpR.indexOf("" + formattr.getDecimalFormatSymbols().getDecimalSeparator()) + 1);
添加到空字符串只是将 char 转换为 String 的技巧。
请注意,还有一个 "grouping symbol",它也可以是逗号或点,例如123,456.78
。您可能想要禁用分组,如下所示:
formattr.setGroupingUsed(false);