Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/309.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/spring-boot/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Getting java.lang.IllegalStateException:在添加BigDecimal变量后无法执行activity的方法。_Java_Android - Fatal编程技术网

Getting java.lang.IllegalStateException:在添加BigDecimal变量后无法执行activity的方法。

Getting java.lang.IllegalStateException:在添加BigDecimal变量后无法执行activity的方法。,java,android,Java,Android,全部- 我的项目(计算技巧)运行良好,直到我添加了一些大十进制变量来帮助进行舍入。现在,当我点击“计算”时,应用力关闭,日志显示: 06-01 14:24:21.246: W/dalvikvm(15364): threadid=1: thread exiting with uncaught exception (group=0x40a4a1f8) 06-01 14:24:21.256: E/AndroidRuntime(15364): FATAL EXCEPTION: main 06-01 1

全部- 我的项目(计算技巧)运行良好,直到我添加了一些大十进制变量来帮助进行舍入。现在,当我点击“计算”时,应用力关闭,日志显示:

 06-01 14:24:21.246: W/dalvikvm(15364): threadid=1: thread exiting with uncaught exception (group=0x40a4a1f8)
06-01 14:24:21.256: E/AndroidRuntime(15364): FATAL EXCEPTION: main
06-01 14:24:21.256: E/AndroidRuntime(15364): java.lang.IllegalStateException: Could not execute method of the activity
06-01 14:24:21.256: E/AndroidRuntime(15364):    at android.view.View$1.onClick(View.java:3044)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at android.view.View.performClick(View.java:3511)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at android.view.View.onKeyUp(View.java:6078)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at android.widget.TextView.onKeyUp(TextView.java:5636)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at android.view.KeyEvent.dispatch(KeyEvent.java:2623)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at android.view.View.dispatchKeyEvent(View.java:5500)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at android.view.ViewGroup.dispatchKeyEvent(ViewGroup.java:1246)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at android.view.ViewGroup.dispatchKeyEvent(ViewGroup.java:1246)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at android.view.ViewGroup.dispatchKeyEvent(ViewGroup.java:1246)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at android.view.ViewGroup.dispatchKeyEvent(ViewGroup.java:1246)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchKeyEvent(PhoneWindow.java:1879)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at com.android.internal.policy.impl.PhoneWindow.superDispatchKeyEvent(PhoneWindow.java:1361)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at android.app.Activity.dispatchKeyEvent(Activity.java:2324)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchKeyEvent(PhoneWindow.java:1806)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at android.view.ViewRootImpl.deliverKeyEventPostIme(ViewRootImpl.java:3327)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at android.view.ViewRootImpl.handleFinishedEvent(ViewRootImpl.java:3300)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at android.view.ViewRootImpl.handleMessage(ViewRootImpl.java:2460)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at android.os.Handler.dispatchMessage(Handler.java:99)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at android.os.Looper.loop(Looper.java:137)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at android.app.ActivityThread.main(ActivityThread.java:4424)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at java.lang.reflect.Method.invokeNative(Native Method)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at java.lang.reflect.Method.invoke(Method.java:511)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at dalvik.system.NativeStart.main(Native Method)
06-01 14:24:21.256: E/AndroidRuntime(15364): Caused by: java.lang.reflect.InvocationTargetException
06-01 14:24:21.256: E/AndroidRuntime(15364):    at java.lang.reflect.Method.invokeNative(Native Method)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at java.lang.reflect.Method.invoke(Method.java:511)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at android.view.View$1.onClick(View.java:3039)
06-01 14:24:21.256: E/AndroidRuntime(15364):    ... 24 more
06-01 14:24:21.256: E/AndroidRuntime(15364): Caused by: java.lang.NumberFormatException: Invalid float: ""
06-01 14:24:21.256: E/AndroidRuntime(15364):    at java.lang.StringToReal.invalidReal(StringToReal.java:63)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at java.lang.StringToReal.parseFloat(StringToReal.java:289)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at java.lang.Float.parseFloat(Float.java:300)
06-01 14:24:21.256: E/AndroidRuntime(15364):    at com.tip.ping.TippingActivity.calculateNumbers(TippingActivity.java:47)
06-01 14:24:21.256: E/AndroidRuntime(15364):    ... 27 more
我的代码是:

 public class TippingActivity extends Activity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
    }
    public void calculateNumbers(View view) {
        EditText text = (EditText)findViewById(R.id.edit_bill);             
        String value;
        value = text.getText().toString();      
        float bill = Float.parseFloat(value);
        BigDecimal billbd;
        billbd = new BigDecimal(bill);


        EditText text2 = (EditText)findViewById(R.id.edit_tip);
        String value2;
        value2 = text2.getText().toString();    
        if(!value2.contains("."))
            value2 = "."+value2;
        float tip = Float.parseFloat(value2);
        BigDecimal tipbd;
        tipbd = new BigDecimal(tip);


        EditText text3 = (EditText)findViewById(R.id.edit_people);
        String value3;
        value3 = text3.getText().toString();

        TextView answer = (TextView) findViewById(R.id.answer);
        String answers;
        answers = answer.getText().toString();
        float answerf = Float.parseFloat(answers);
        BigDecimal answerbd;
        answerbd = new BigDecimal(answerf);
        answerbd.setScale(2);   
        TextView quick_answer = (TextView) findViewById(R.id.quick_answer);
        String qanswers;
        qanswers = quick_answer.getText().toString();
        float qanswerf = Float.parseFloat(qanswers);
        BigDecimal qanswerbd;
        qanswerbd = new BigDecimal(qanswerf);       

        float l3 = Float.parseFloat(value3);
        BigDecimal l3bd;
        l3bd = new BigDecimal(l3);

        qanswerbd = billbd.multiply(tipbd).add(billbd);
        qanswerbd.setScale(2, RoundingMode.HALF_UP);
        String resultbd;
        resultbd = qanswerbd.toString();   

        quick_answer.setText(resultbd);     
    }
}

提前谢谢

看起来像一个空的浮点值,但是没有行号很难说(第47行是…?)

原因:java.lang.NumberFormatException:无效浮点:“”


如果此时记录/打印
值,是否会返回任何内容?

看起来像一个空的浮点值,但如果没有行号就很难说(第47行是…?)

原因:java.lang.NumberFormatException:无效浮点:“”


如果此时记录/打印
value
,是否会返回任何内容?

看起来您正在尝试从空字符串解析浮点值。在使用输入之前,您需要对输入进行一些健全性检查,或者至少围绕Float.parseFloat之类的函数,这些函数可能会因Try-Catch(在本例中为NumberFormatException)而失败,该函数会为用户提供某种有用的反馈(可能是toast)

看起来您正试图从空字符串解析浮点值。在使用输入之前,您需要对输入进行一些健全性检查,或者至少围绕Float.parseFloat之类的函数,这些函数可能会因Try-Catch(在本例中为NumberFormatException)而失败,该函数会为用户提供某种有用的反馈(可能是toast)

你确定你已经在AndroidManifest.xml中声明了TippingActivity吗?

你确定你已经在AndroidManifest.xml中声明了TippingActivity吗?

对不起,我是android新手。什么是“日志/打印值”?感谢您的回答,并对行号感到抱歉。Log.d(“Appname”,“Value:+Value”);并观察Logcat以查看运行时打印的值。它有点像普通java中的System.out.println()。(如果确实需要,也可以使用System.out)。检查值并确保它不是空字符串,这将在Float.parseFloat(value)中引发数字格式异常。谢谢。我查了一下,号码出来了,所以它一定是另一个输入字段。对不起,我是android新手。什么是“日志/打印值”?感谢您的回答,并对行号感到抱歉。Log.d(“Appname”,“Value:+Value”);并观察Logcat以查看运行时打印的值。它有点像普通java中的System.out.println()。(如果确实需要,也可以使用System.out)。检查值并确保它不是空字符串,这将在Float.parseFloat(value)中引发数字格式异常。谢谢。我检查过了,数字出来了,所以它一定是另一个输入字段。谢谢,我会再次检查输入。谢谢,我会再次检查输入。
EditText text = (EditText)findViewById(R.id.edit_bill);
String value = text.getText().toString();