Android App 在第 54 行(Integer.parseInt)崩溃,不完全确定原因

Posted

技术标签:

【中文标题】Android App 在第 54 行(Integer.parseInt)崩溃,不完全确定原因【英文标题】:Android App crashes at line 54(Integer.parseInt) and not entirely sure why 【发布时间】:2012-03-16 13:10:46 【问题描述】:

我一直在用我的手机调试我的应用程序,我得到的所有 logcat 错误都参考了我的活动中的第 54 行,我将一个字符串解析为一个 Int。该应用程序的基本思想是一个便士转换器,用户在其中输入他们想要转换的便士数量,然后从四分之一分成剩余的便士。在这一点上,我不确定我是否正确地捕捉到了事件,并且在使用匿名内部类并只是在类中实现方面来回走动。

这是java应用程序的代码:

public class PennyConverterActivity extends Activity


    EditText et;
    TextView tv;

    int cents;
    int remaining;
    int quarters;
    int dimes;
    int nickels;
    int pennies;
    String result;

    @Override

    public void onCreate(Bundle b)
    
        super.onCreate(b);
        setContentView(R.layout.main);

        et = (EditText) findViewById(R.id.penny);

        et.setText(result);

        et.setOnKeyListener(new View.OnKeyListener() 
        

            @Override
            public boolean onKey(View v, int keyCode, KeyEvent event) 
            
                if((event.getAction() == KeyEvent.ACTION_DOWN) && (keyCode == KeyEvent.KEYCODE_ENTER))
                
                    result = et.getText().toString();
                    return (true);
                

                return (true);
            
        ); 


        cents = Integer.parseInt(result); //LogCat error refers to this line

        tv = (TextView) findViewById(R.id.quarters);

        quarters = cents / 25;
        tv.setText(R.string.quarters);
        remaining = cents % 25;

        tv = (TextView) findViewById(R.id.dimes);

        dimes = remaining / 10;
        tv.setText(R.string.dimes);
        remaining = remaining % 10;

        tv = (TextView) findViewById(R.id.nickels);

        nickels = remaining / 5;
        tv.setText(R.string.nickles);

        tv = (TextView) findViewById(R.id.pennies);

        pennies = remaining % 5;
        tv.setText(R.string.pennies);

    


还有我的 Logcat 错误

02-26 15:26:30.602: E/androidRuntime(25020): FATAL EXCEPTION: main
02-26 15:26:30.602: E/AndroidRuntime(25020): java.lang.RuntimeException: Unable to start activity ComponentInfoCS211D.HW03.PennyConverter/CS211D.HW03.PennyConverter.PennyConverterActivity: java.lang.NumberFormatException: unable to parse 'null' as integer
02-26 15:26:30.602: E/AndroidRuntime(25020):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647)
02-26 15:26:30.602: E/AndroidRuntime(25020):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
02-26 15:26:30.602: E/AndroidRuntime(25020):    at android.app.ActivityThread.access$1500(ActivityThread.java:117)
02-26 15:26:30.602: E/AndroidRuntime(25020):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
02-26 15:26:30.602: E/AndroidRuntime(25020):    at android.os.Handler.dispatchMessage(Handler.java:99)
02-26 15:26:30.602: E/AndroidRuntime(25020):    at android.os.Looper.loop(Looper.java:130)
02-26 15:26:30.602: E/AndroidRuntime(25020):    at android.app.ActivityThread.main(ActivityThread.java:3683)
02-26 15:26:30.602: E/AndroidRuntime(25020):    at java.lang.reflect.Method.invokeNative(Native Method)
02-26 15:26:30.602: E/AndroidRuntime(25020):    at java.lang.reflect.Method.invoke(Method.java:507)
02-26 15:26:30.602: E/AndroidRuntime(25020):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
02-26 15:26:30.602: E/AndroidRuntime(25020):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
02-26 15:26:30.602: E/AndroidRuntime(25020):    at dalvik.system.NativeStart.main(Native Method)
02-26 15:26:30.602: E/AndroidRuntime(25020): Caused by: java.lang.NumberFormatException: unable to parse 'null' as integer
02-26 15:26:30.602: E/AndroidRuntime(25020):    at java.lang.Integer.parseInt(Integer.java:356)
02-26 15:26:30.602: E/AndroidRuntime(25020):    at java.lang.Integer.parseInt(Integer.java:332)
02-26 15:26:30.602: E/AndroidRuntime(25020):    at CS211D.HW03.PennyConverter.PennyConverterActivity.onCreate(PennyConverterActivity.java:52)
02-26 15:26:30.602: E/AndroidRuntime(25020):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
02-26 15:26:30.602: E/AndroidRuntime(25020):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
02-26 15:26:30.602: E/AndroidRuntime(25020):    ... 11 more

【问题讨论】:

这是一个基本的java问题。尝试了解您正在使用的方法及其预期内容,并检查您传入的内容并确保其有效。 【参考方案1】:

问题是你没有初始化result,当你调用Integer.parseInt(result)时,它无法解析null。从您得到的异常中可以看出这一点:

原因:java.lang.NumberFormatException:无法将“null”解析为整数

【讨论】:

【参考方案2】:

日志明确指出 Java 无法将“null”解析为整数。

【讨论】:

【参考方案3】:

就像上面的人说你正在解析null,尝试初始化你的变量,以防你的方法没有给你结果,可能这个结果不是你想要的,但你的代码不会崩溃。

result = 0;

这也不起作用:result = ""

【讨论】:

以上是关于Android App 在第 54 行(Integer.parseInt)崩溃,不完全确定原因的主要内容,如果未能解决你的问题,请参考以下文章

一个APP能启动另一个APP么

逐行解析 2 个文件,在第 3 个文件中搜索和替换

Android命令行编译APP

在第 0 行,表达式预期错误(Nand2tetris CPU-emulator)

我得到了预期的BEGIN_ARRAY,但是在使用Android中的Retrofit(java)尝试获取json时,在第1行第2列路径$中是BEGIN_OBJECT

通过命令行安装Android app