04-29 09:13:24.447: I/dalvikvm(2981): threadid=3: reacting to signal 3
04-29 09:13:24.487: E/AndroidRuntime(2981): FATAL EXCEPTION: main
04-29 09:13:24.487: E/AndroidRuntime(2981): java.lang.RuntimeException: Unable to start activity ComponentInfo{cn.com.arithmetic/cn.com.arithmetic.ArithmeticActivity}: java.lang.NumberFormatException: Invalid double: ""
04-29 09:13:24.487: E/AndroidRuntime(2981): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1956)
04-29 09:13:24.487: E/AndroidRuntime(2981): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)
04-29 09:13:24.487: E/AndroidRuntime(2981): at android.app.ActivityThread.access$600(ActivityThread.java:123)
04-29 09:13:24.487: E/AndroidRuntime(2981): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147)
04-29 09:13:24.487: E/AndroidRuntime(2981): at android.os.Handler.dispatchMessage(Handler.java:99)
04-29 09:13:24.487: E/AndroidRuntime(2981): at android.os.Looper.loop(Looper.java:137)
04-29 09:13:24.487: E/AndroidRuntime(2981): at android.app.ActivityThread.main(ActivityThread.java:4424)
04-29 09:13:24.487: E/AndroidRuntime(2981): at java.lang.reflect.Method.invokeNative(Native Method)
04-29 09:13:24.487: E/AndroidRuntime(2981): at java.lang.reflect.Method.invoke(Method.java:511)
04-29 09:13:24.487: E/AndroidRuntime(2981): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
04-29 09:13:24.487: E/AndroidRuntime(2981): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
04-29 09:13:24.487: E/AndroidRuntime(2981): at dalvik.system.NativeStart.main(Native Method)
04-29 09:13:24.487: E/AndroidRuntime(2981): Caused by: java.lang.NumberFormatException: Invalid double: ""
04-29 09:13:24.487: E/AndroidRuntime(2981): at java.lang.StringToReal.invalidReal(StringToReal.java:63)
04-29 09:13:24.487: E/AndroidRuntime(2981): at java.lang.StringToReal.parseDouble(StringToReal.java:248)
04-29 09:13:24.487: E/AndroidRuntime(2981): at java.lang.Double.parseDouble(Double.java:295)
04-29 09:13:24.487: E/AndroidRuntime(2981): at java.lang.Double.valueOf(Double.java:332)
04-29 09:13:24.487: E/AndroidRuntime(2981): at cn.com.arithmetic.ArithmeticActivity.onCreate(ArithmeticActivity.java:29)
04-29 09:13:24.487: E/AndroidRuntime(2981): at android.app.Activity.performCreate(Activity.java:4465)
04-29 09:13:24.487: E/AndroidRuntime(2981): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
04-29 09:13:24.487: E/AndroidRuntime(2981): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920)
04-29 09:13:24.487: E/AndroidRuntime(2981): ... 11 more
这错误很明显说运行时编译错误是由于数值转化错误,无效的Double,下面看看这错误程序:仔细看看下面红色的代码
package cn.com.arithmetic;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
public class ArithmeticActivity extends Activity {
private EditText text1=null;
private EditText text2=null;
private Double num1=0.0;
private Double num2=0.0;
private TextView result=null;
private TextView sign=null;
private Button add=null;
private Button reduce=null;
private Button ride=null;
private Button div=null;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
text1=(EditText) findViewById(R.id.num1); // 取得输入内容的ID
text2=(EditText) findViewById(R.id.num2); // 取得输入的内容的ID
num1=Double.valueOf(text1.getText().toString()); //将第一个数转化为Doubel类型
num2=Double.valueOf(text2.getText().toString()); //将第二个数转化为Doubel类型
sign=(TextView) findViewById(R.id.sign); // 取得操作的形式的ID
result=(TextView) findViewById(R.id.result); //取得结果按钮的ID
add=(Button) findViewById(R.id.add); //取得操作功能按钮的ID
reduce=(Button) findViewById(R.id.reduce); //取得操作功能按钮的ID
ride=(Button) findViewById(R.id.ride); //取得操作功能按钮的ID
div=(Button) findViewById(R.id.div); //取得操作功能按钮的ID
add.setOnClickListener(new AddListener()); //点击加法操作
}
// 加法操作
private class AddListener implements OnClickListener{
public void onClick(View v) {
sign.setText("+"); //显示加法形式
result.setText((num1+num2)+""); //显示结果
}
}
}
你们发现没有: num1=Double.valueOf(text1.getText().toString()); //将第一个数转化为Doubel类型
num2=Double.valueOf(text2.getText().toString()); //将第二个数转化为Doubel类型
这两句代码都在onCreate方法中,程序已运行首先运行这个方法。然而之前还没有获取text1,text2的字符串的值,所以 num1=Double.valueOf(text1.getText().toString());里面的text1.getText().toString()是null值,所以报出上面的错误提示
所以正确的程序应该在
num1=Double.valueOf(text1.getText().toString()); //将第一个数转化为Doubel类型
num2=Double.valueOf(text2.getText().toString()); //将第二个数转化为Doubel类型
这两句代码运行之前给text1,text2赋值
正确代码如下:
package cn.com.arithmetic;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
public class ArithmeticActivity extends Activity {
private EditText text1=null;
private EditText text2=null;
private Double num1=0.0;
private Double num2=0.0;
private TextView result=null;
private TextView sign=null;
private Button add=null;
private Button reduce=null;
private Button ride=null;
private Button div=null;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
text1=(EditText) findViewById(R.id.num1); // 取得输入的内容
text2=(EditText) findViewById(R.id.num2); // 取得输入的内容
sign=(TextView) findViewById(R.id.sign); // 取得操作的形式
result=(TextView) findViewById(R.id.result); //取得结果按钮
add=(Button) findViewById(R.id.add); //取得操作功能按钮
reduce=(Button) findViewById(R.id.reduce); //取得操作功能按钮
ride=(Button) findViewById(R.id.ride); //取得操作功能按钮
div=(Button) findViewById(R.id.div); //取得操作功能按钮
add.setOnClickListener(new AddListener()); //点击加法操作
}
// 加法操作
private class AddListener implements OnClickListener{
public void onClick(View v) {
num1=Double.valueOf(text1.getText().toString()); //将第一个数转化为Doubel类型
num2=Double.valueOf(text2.getText().toString()); //将第二个数转化为Doubel类型
sign.setText("+"); //显示加法形式
result.setText((num1+num2)+""); //显示结果
}
}
}
最后效果为: main.xml代码没有附上,并且上面代码只是实现加法而已