Android addTextChangedListener强制关闭

Android addTextChangedListener强制关闭,android,android-event,Android,Android Event,我在四个文本框中添加了一个TextChangedListener,下面是我实现的代码: public class PasswordActivity extends Activity{ /*This will store the password temporarily */ private int passcodeString; private String LOG_TAG="Password_Activity"; EditText passOne = (EditText) findViewB

我在四个文本框中添加了一个TextChangedListener,下面是我实现的代码:

public class PasswordActivity extends Activity{

/*This will store the password temporarily */
private int passcodeString;
private String LOG_TAG="Password_Activity";
EditText passOne = (EditText) findViewById(R.id.passcodeOne);
EditText passTwo = (EditText) findViewById(R.id.passcodeTwo);
EditText passThree = (EditText) findViewById(R.id.passcodeThree);
EditText passFour = (EditText) findViewById(R.id.passcodeFour);



@Override
protected void onCreate(Bundle savedInstanceState) {
    // TODO Auto-generated method stub
    super.onCreate(savedInstanceState);
    setContentView(R.layout.password);

    passOne.addTextChangedListener(new CustomTextWatcher(passOne)); 
}


private class CustomTextWatcher implements TextWatcher {
    private EditText mEditText;

    public CustomTextWatcher(EditText e) { 
        mEditText = e;
    }

    public void beforeTextChanged(CharSequence s, int start, int count, int after) {
    }

    public void onTextChanged(CharSequence s, int start, int before, int count) {
    }

    public void afterTextChanged(Editable s) {
        Log.d(LOG_TAG, s.toString());
    }
}}
但不知怎的,它给了一个力接近,我不知道为什么它会导致这个问题。以下是错误日志:

01-14 21:57:37.396: W/dalvikvm(608): threadid=1: thread exiting with uncaught exception (group=0x40015560)
01-14 21:57:37.541: E/AndroidRuntime(608): FATAL EXCEPTION: main
01-14 21:57:37.541: E/AndroidRuntime(608): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.pack.android.email.service/com.pack.android.activity.PasswordActivity}: java.lang.NullPointerException
01-14 21:57:37.541: E/AndroidRuntime(608):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1569)
01-14 21:57:37.541: E/AndroidRuntime(608):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
01-14 21:57:37.541: E/AndroidRuntime(608):  at android.app.ActivityThread.access$1500(ActivityThread.java:117)
01-14 21:57:37.541: E/AndroidRuntime(608):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
01-14 21:57:37.541: E/AndroidRuntime(608):  at android.os.Handler.dispatchMessage(Handler.java:99)
01-14 21:57:37.541: E/AndroidRuntime(608):  at android.os.Looper.loop(Looper.java:123)
01-14 21:57:37.541: E/AndroidRuntime(608):  at android.app.ActivityThread.main(ActivityThread.java:3683)
01-14 21:57:37.541: E/AndroidRuntime(608):  at java.lang.reflect.Method.invokeNative(Native Method)
01-14 21:57:37.541: E/AndroidRuntime(608):  at java.lang.reflect.Method.invoke(Method.java:507)
01-14 21:57:37.541: E/AndroidRuntime(608):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
01-14 21:57:37.541: E/AndroidRuntime(608):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
01-14 21:57:37.541: E/AndroidRuntime(608):  at dalvik.system.NativeStart.main(Native Method)
01-14 21:57:37.541: E/AndroidRuntime(608): Caused by: java.lang.NullPointerException
01-14 21:57:37.541: E/AndroidRuntime(608):  at android.app.Activity.findViewById(Activity.java:1647)
01-14 21:57:37.541: E/AndroidRuntime(608):  at com.pack.android.activity.PasswordActivity.<init>(PasswordActivity.java:16)
01-14 21:57:37.541: E/AndroidRuntime(608):  at java.lang.Class.newInstanceImpl(Native Method)
01-14 21:57:37.541: E/AndroidRuntime(608):  at java.lang.Class.newInstance(Class.java:1409)
01-14 21:57:37.541: E/AndroidRuntime(608):  at android.app.Instrumentation.newActivity(Instrumentation.java:1021)
01-14 21:57:37.541: E/AndroidRuntime(608):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1561)
01-14 21:57:37.541: E/AndroidRuntime(608):  ... 11 more
01-14 21:57:37.396:W/dalvikvm(608):threadid=1:线程以未捕获异常退出(组=0x40015560)
01-14 21:57:37.541:E/AndroidRuntime(608):致命异常:主
01-14 21:57:37.541:E/AndroidRuntime(608):java.lang.RuntimeException:无法实例化活动组件信息{com.pack.android.email.service/com.pack.android.activity.PasswordActivity}:java.lang.NullPointerException
01-14 21:57:37.541:E/AndroidRuntime(608):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1569)
01-14 21:57:37.541:E/AndroidRuntime(608):在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
01-14 21:57:37.541:E/AndroidRuntime(608):在android.app.ActivityThread.access$1500(ActivityThread.java:117)
01-14 21:57:37.541:E/AndroidRuntime(608):在android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
01-14 21:57:37.541:E/AndroidRuntime(608):在android.os.Handler.dispatchMessage(Handler.java:99)上
01-1421:57:37.541:E/AndroidRuntime(608):在android.os.Looper.loop(Looper.java:123)上
01-14 21:57:37.541:E/AndroidRuntime(608):位于android.app.ActivityThread.main(ActivityThread.java:3683)
01-14 21:57:37.541:E/AndroidRuntime(608):位于java.lang.reflect.Method.Invokenactive(本机方法)
01-14 21:57:37.541:E/AndroidRuntime(608):在java.lang.reflect.Method.invoke(Method.java:507)
01-14 21:57:37.541:E/AndroidRuntime(608):在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
01-14 21:57:37.541:E/AndroidRuntime(608):位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
01-14 21:57:37.541:E/AndroidRuntime(608):在dalvik.system.NativeStart.main(本机方法)
01-14 21:57:37.541:E/AndroidRuntime(608):由以下原因引起:java.lang.NullPointerException
01-14 21:57:37.541:E/AndroidRuntime(608):在android.app.Activity.findViewById(Activity.java:1647)上
01-14 21:57:37.541:E/AndroidRuntime(608):在com.pack.android.activity.PasswordActivity.(PasswordActivity.java:16)
01-14 21:57:37.541:E/AndroidRuntime(608):位于java.lang.Class.newInstanceImpl(本机方法)
01-14 21:57:37.541:E/AndroidRuntime(608):在java.lang.Class.newInstance(Class.java:1409)中
01-14 21:57:37.541:E/AndroidRuntime(608):在android.app.Instrumentation.newActivity(Instrumentation.java:1021)上
01-14 21:57:37.541:E/AndroidRuntime(608):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1561)
01-1421:57:37.541:E/AndroidRuntime(608):。。。还有11个
我对android开发非常陌生。

试试:

public class PasswordActivity extends Activity{

/*This will store the password temporarily */
private int passcodeString;
private String LOG_TAG="Password_Activity";
EditText passOne;
EditText passTwo;
EditText passThree;
EditText passFour;



@Override
protected void onCreate(Bundle savedInstanceState) {
    // TODO Auto-generated method stub
    super.onCreate(savedInstanceState);
    setContentView(R.layout.password);

    passOne = (EditText) findViewById(R.id.passcodeOne);
    passTwo = (EditText) findViewById(R.id.passcodeTwo);
    passThree = (EditText) findViewById(R.id.passcodeThree);
    passFour = (EditText) findViewById(R.id.passcodeFour);


    passOne.addTextChangedListener(new CustomTextWatcher(passOne)); 
}


private class CustomTextWatcher implements TextWatcher {
    private EditText mEditText;

    public CustomTextWatcher(EditText e) { 
        mEditText = e;
    }

    public void beforeTextChanged(CharSequence s, int start, int count, int after) {
    }

    public void onTextChanged(CharSequence s, int start, int before, int count) {
    }

    public void afterTextChanged(Editable s) {
        Log.d(LOG_TAG, s.toString());
    }
}}

出现错误是因为在调用
setContentView()
之前,您试图使用
findViewById()

您正在静态初始值设定项块中调用findViewById,该块在onCreate方法之前调用。因此布局尚未设置,视图也不存在。

move

  EditText passOne = (EditText) findViewById(R.id.passcodeOne);
  EditText passTwo = (EditText) findViewById(R.id.passcodeTwo);
  EditText passThree = (EditText) findViewById(R.id.passcodeThree);
  EditText passFour = (EditText) findViewById(R.id.passcodeFour);

onCreate()
方法。

是的,这就像一个符咒。。。另外,如何获取当前选定的文本框?因为我可以将开关盒用于不同的操作。请尝试
mEditText.getId()
获取视图的ID,然后在其上运行开关以查看使用的是哪一个。这会给我一个长整数。。。不同设备的ID是否相同?使用
android:ID
setId()
为其定义ID的视图的ID将始终相同。