在这篇文章中,我们将为您详细介绍解析int时出现NumberFormatException的内容,并且讨论关于intnumber的相关问题。此外,我们还会涉及一些关于"xceptioninthread
在这篇文章中,我们将为您详细介绍解析int时出现NumberFormatException的内容,并且讨论关于int number的相关问题。此外,我们还会涉及一些关于"xception in thread "main" java.lang.NumberFormatException: For input string: "20、android – java.lang.NumberFormatException:无效的int:“”EXCEPTION、android-hexString.toInt(32)NumberFormatException、Android上的Integer.parseInt和NumberFormatException的知识,以帮助您更全面地了解这个主题。
本文目录一览:- 解析int时出现NumberFormatException(int number)
- "xception in thread "main" java.lang.NumberFormatException: For input string: "20
- android – java.lang.NumberFormatException:无效的int:“”EXCEPTION
- android-hexString.toInt(32)NumberFormatException
- Android上的Integer.parseInt和NumberFormatException
解析int时出现NumberFormatException(int number)
因此,我正在制作可以访问给定文件并从中保存/读取文件的文件读取器/写入器。从文件读取时遇到问题。内容是整数,字符串和由“ |”分隔的双精度
定界符。我正在使用StringTokenizer来分隔标记并将它们保存到每个单独的变量中,但是当我读取整数时,即使字符串仅包含一个整数,我也会得到NumberFormatException。
这是代码:
FileReader fr = new FileReader(filename);BufferedReader buff = new BufferedReader(fr);String line;while ((line = buff.readLine()) != null) { StringTokenizer st = new StringTokenizer(line, "|"); while (st.hasMoreElements()) { int Id = Integer.parseInt(st.nextToken()); String Name = st.nextToken(); double cordX = Double.parseDouble(st.nextToken()); double cordY = Double.parseDouble(st.nextToken()); }}
该文件的示例行:
8502113|Aarau|47.391355|8.051251
和错误:
java.lang.NumberFormatException: For input string: "8502113"at java.lang.NumberFormatException.forInputString(NumberFormatException.java:65)at java.lang.Integer.parseInt(Integer.java:580)at java.lang.Integer.parseInt(Integer.java:615)at storage.FileUtilities.readCitiesFromFile(FileUtilities.java:63)at basics.Test.main(Test.java:16)
我在这里想念什么吗?StringTokenizer是否以某种我不知道的方式篡改字符串?
编辑:这是创建文件的代码:
FileWriter fw = new FileWriter(filename, !overwrite); // For FileWriter true = append, false = overwrite, so we flip the value. BufferedWriter buff = new BufferedWriter(fw); String coordConvertor; for (int i = 0; i <= cities.size() - 1; i++) { buff.write(Integer.toString(cities.get(i).getId())); buff.write("|"); buff.write(cities.get(i).getName()); buff.write("|"); coordConvertor = Double.toString(cities.get(i).getCoord().getX()); buff.write(coordConvertor); buff.write("|"); coordConvertor = Double.toString(cities.get(i).getCoord().getY()); buff.write(coordConvertor); buff.newLine();
答案1
小编典典您使用 st.nextToken()* 检索的 字符串中 有 隐藏的unicode字符 。使用此代码删除它们 ***
int Id = Integer.parseInt(st.nextToken().replaceAll("\\p{C}", ""));String Name = st.nextToken().replaceAll("\\p{C}", "");double cordX = Double.parseDouble(st.nextToken().replaceAll("\\p{C}", ""));double cordY = Double.parseDouble(st.nextToken().replaceAll("\\p{C}", ""));
"xception in thread "main" java.lang.NumberFormatException: For input string: "20
spark.SparkContext: Registered listener com.cloudera.spark.lineage.ClouderaNavigatorListener
"xception in thread "main" java.lang.NumberFormatException: For input string: "20
at java.lang.NumberFormatException.forInputString(NumberFormatException.java:65)
at java.lang.Integer.parseInt(Integer.java:492)
at java.lang.Integer.valueOf(Integer.java:582)
at com.xiaodao.spark.examples.ml.AdaoKMeanService.main(AdaoKMeanService.java:166)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at org.apache.spark.deploy.SparkSubmit$.org$apache$spark$deploy$SparkSubmit$$runMain(SparkSubmit.scala:730)
at org.apache.spark.deploy.SparkSubmit$.doRunMain$1(SparkSubmit.scala:181)
at org.apache.spark.deploy.SparkSubmit$.submit(SparkSubmit.scala:206)
at org.apache.spark.deploy.SparkSubmit$.main(SparkSubmit.scala:121)
at org.apache.spark.deploy.SparkSubmit.main(SparkSubmit.scala)
17/10/12 17:42:02 INFO spark.SparkContext: Invoking stop() from shutdown hook
17/10/12 17:42:02 INFO ui.SparkUI: Stopped Spark web UI at http://192.168.1.30:4041
17/10/12 17:42:02 INFO spark.MapOutputTrackerMasterEndpoint: MapOutputTrackerMasterEndpoint stopped!
17/10/12 17:42:02 INFO storage.MemoryStore: MemoryStore cleared
android – java.lang.NumberFormatException:无效的int:“”EXCEPTION
错误就行了
if (a=="" && b=="")
并且也在线
int result = Integer.parseInt(a) + Integer.parseInt(b); t1.setText(Integer.toString(result));
Calci.java
package com.example.calculator; import android.app.Activity; import android.app.AlertDialog; import android.content.Context; import android.content.DialogInterface; import android.os.Bundle; import android.view.View; import android.view.inputmethod.InputMethodManager; import android.widget.Button; import android.widget.EditText; import android.widget.TextView; public class Calci extends Activity { TextView t1; EditText e1,e2; Button add,sub,mul,div; Context c=this; String b,a; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_calci); e1 = (EditText) findViewById(R.id.EditText01); e2 = (EditText) findViewById(R.id.EditText02); add = (Button) findViewById(R.id.add); sub = (Button) findViewById(R.id.sub); mul = (Button) findViewById(R.id.mul); div = (Button) findViewById(R.id.div); t1 = (TextView) findViewById(R.id.textView1); a = e1.getText().toString(); b = e2.getText().toString(); add.setonClickListener(new View.OnClickListener() { @Override public void onClick(View arg0) { if (a=="" && b==""){ AlertDialog.Builder a1 = new AlertDialog.Builder(c); // Setting Dialog Title a1.setTitle("Alert Dialog"); // Setting Dialog Message a1.setMessage("PLEASE ENTER SOMETHING"); a1.setPositiveButton("yes",new DialogInterface.OnClickListener() { public void onClick(DialogInterface dialog,int button1) { // if this button is clicked,close // current activity dialog.cancel(); } }); // Showing Alert Message AlertDialog alertDialog = a1.create(); a1.show(); } else{ int result = Integer.parseInt(a) + Integer.parseInt(b); t1.setText(Integer.toString(result)); InputMethodManager imm = (InputMethodManager)getSystemService( Context.INPUT_METHOD_SERVICE); imm.hideSoftInputFromWindow(add.getwindowToken(),0); } } }); } }
logcat的:
03-19 15:42:21.165: E/Trace(25381): error opening trace file: Permission denied (13) 03-19 15:42:21.165: D/ActivityThread(25381): setTargetHeaputilization:0.25 03-19 15:42:21.165: D/ActivityThread(25381): setTargetHeapIdealFree:8388608 03-19 15:42:21.165: D/ActivityThread(25381): setTargetHeapConcurrentStart:2097152 03-19 15:42:21.385: D/libEGL(25381): loaded /system/lib/egl/libEGL_adreno200.so 03-19 15:42:21.465: D/libEGL(25381): loaded /system/lib/egl/libGLESv1_CM_adreno200.so 03-19 15:42:21.475: D/libEGL(25381): loaded /system/lib/egl/libGLESv2_adreno200.so 03-19 15:42:21.475: I/Adreno200-EGL(25381): <qeglDrvAPI_eglInitialize:299>: EGL 1.4 QUALCOMM build: (Merge) 03-19 15:42:21.475: I/Adreno200-EGL(25381): Build Date: 07/09/13 Tue 03-19 15:42:21.475: I/Adreno200-EGL(25381): Local Branch: AU_41 03-19 15:42:21.475: I/Adreno200-EGL(25381): Remote Branch: 03-19 15:42:21.475: I/Adreno200-EGL(25381): Local Patches: 03-19 15:42:21.475: I/Adreno200-EGL(25381): Reconstruct Branch: 03-19 15:42:21.675: D/Openglrenderer(25381): Enabling debug mode 0 03-19 15:42:24.325: D/AndroidRuntime(25381): Shutting down VM 03-19 15:42:24.325: W/dalvikvm(25381): threadid=1: thread exiting with uncaught exception (group=0x41972378) 03-19 15:42:24.395: E/AndroidRuntime(25381): FATAL EXCEPTION: main 03-19 15:42:24.395: E/AndroidRuntime(25381): java.lang.NumberFormatException: Invalid int: "" 03-19 15:42:24.395: E/AndroidRuntime(25381): at java.lang.Integer.invalidInt(Integer.java:138) 03-19 15:42:24.395: E/AndroidRuntime(25381): at java.lang.Integer.parseInt(Integer.java:359) 03-19 15:42:24.395: E/AndroidRuntime(25381): at java.lang.Integer.parseInt(Integer.java:332) 03-19 15:42:24.395: E/AndroidRuntime(25381): at com.example.calculator.Calci$1.onClick(Calci.java:67) 03-19 15:42:24.395: E/AndroidRuntime(25381): at android.view.View.performClick(View.java:4147) 03-19 15:42:24.395: E/AndroidRuntime(25381): at android.view.View$PerformClick.run(View.java:17161) 03-19 15:42:24.395: E/AndroidRuntime(25381): at android.os.Handler.handleCallback(Handler.java:615) 03-19 15:42:24.395: E/AndroidRuntime(25381): at android.os.Handler.dispatchMessage(Handler.java:92) 03-19 15:42:24.395: E/AndroidRuntime(25381): at android.os.Looper.loop(Looper.java:213) 03-19 15:42:24.395: E/AndroidRuntime(25381): at android.app.ActivityThread.main(ActivityThread.java:4787) 03-19 15:42:24.395: E/AndroidRuntime(25381): at java.lang.reflect.Method.invokeNative(Native Method) 03-19 15:42:24.395: E/AndroidRuntime(25381): at java.lang.reflect.Method.invoke(Method.java:511) 03-19 15:42:24.395: E/AndroidRuntime(25381): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789) 03-19 15:42:24.395: E/AndroidRuntime(25381): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:556) 03-19 15:42:24.395: E/AndroidRuntime(25381): at dalvik.system.NativeStart.main(Native Method) 03-19 15:42:25.685: I/Process(25381): Sending signal. PID: 25381 SIG: 9
任何人都知道如何解决这些堆栈跟踪错误.
解决方法
a = e1.getText().toString().trim(); b = e2.getText().toString().trim(); if (a.equals("") && b.equals("") ){ }
android-hexString.toInt(32)NumberFormatException
我有一个32位十六进制值,我希望将其转换为整数.
给定十六进制字符串C71C5E00,以下方法都提供以下错误:
java.lang.NumberFormatException: For input string: “C71C5E00”
"C71C5E00".toInt(32)
Integer.valueOf("C71C5E00", 32)
Kotlin docs声明Int表示一个32位有符号整数,因此它的值不是太大而不能装入Int.我曾尝试以0x开头的字符串,但是徒劳无功.
编辑:根据我尝试的this问题:
java.lang.Integer.parseInt("C71C5E00", 32)
不幸的是,我仍然收到相同的错误.
我不常碰Android或Kotlin,所以请原谅我的无知.
解决方法:
首先,您似乎误解了基数,它是valueOf和parseInt中的第二个参数,并且是扩展函数toInt的唯一参数.它不代表目标数字类型中的位,而是告诉方法如何转换字符串.请注意,还有第二个问题,我稍后会再讲.
基数是基础编号系统的基数.默认情况下为10(0参数toInt()方法.toInt()调用parseInt,如下所示:
public static int parseInt(String s) throws NumberFormatException {
return parseInt(s,10);
}
如您所见,它使用radix =10.同样,数字类型的位在这里不相关. Wikipedia很好地涵盖了它,而Java或多或少地遵循相同的系统.如您所见,16对应于十六进制.因此,此处使用的适当基数为16.
但是,就像我提到的,还有第二个问题.它仍然会崩溃,因为无法解析该值.结果数为3340525056,该值大于最大int值2147483647.
这意味着您不能使用任何int方法;您将需要使用Long.
因此,对于您的情况,这很好:
val x = "C71C5E00".toLong(16)
同样,基数是要使用的数字系统,而不是结果数字中的位数.如果是这样,则需要长时间使用64.
Android上的Integer.parseInt和NumberFormatException
我在Android应用中运行了以下代码
Integer.parseInt("+91");
在Android 5.0(Lollipop)中,它
没有 引发任何+91
整数异常。但是在Android
4.4.x(KitKat)和更低版本中,它抛出:
NumberFormatException:无效的Int:“ +91”
Android版本如何造成这种差异?
答案1
小编典典+
在此提交中添加了对显式的支持:
Support explicit + in Byte, Short, Integer, Long.Bug: 5239391Change-Id: I2b25228815d70d570d537db0ed9b5b759f25b5a3
从开始包含在内android-5.0.0_r1
。如果您已获取Git存储库,则可以使用以下命令进行验证:
git tag --contains 6b40837ee3a023bba698c38fd6d6e46ae0065a55
这给你
android-5.0.0_r1android-5.0.0_r2android-5.0.0_r3...
尽管文档可以给见解 ,为什么 进行了更改(实现Java 7的行为,其他的答案指出),分析源代码的历史给出最准确的答案 时,
行为改变,因为文件不一定与实现。
今天关于解析int时出现NumberFormatException和int number的介绍到此结束,谢谢您的阅读,有关"xception in thread "main" java.lang.NumberFormatException: For input string: "20、android – java.lang.NumberFormatException:无效的int:“”EXCEPTION、android-hexString.toInt(32)NumberFormatException、Android上的Integer.parseInt和NumberFormatException等更多相关知识的信息可以在本站进行查询。
本文标签: