реализовать слушателя в отдельном классе

У меня проблема с реализацией прослушивателя кнопок в отдельном классе. Код:

<Button 
    android:id ="@+button/bottone"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text = "Button"
    />

основной класс:

public class MainActivity extends Activity {

private final Context main_context = this.getApplicationContext(); 

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    Button b = (Button)findViewById(R.button.bottone);
    Log.i("AAAAAAAAAAAA", "1");

    OnClickListener l = new MyClickListener(this);
    b.setOnClickListener(l);
    Log.i("AAAAAAAAAAAA", "2");


    setContentView(R.layout.activity_main);
}

public Context getContext() {
    return main_context;
}

и реализация слушателя

public class MyClickListener implements OnClickListener {
private final Context cntx;

public MyClickListener(Context c) {
    cntx = c;
}
@Override
public void onClick(View v) {
    // TODO Auto-generated method stub
    Log.i("ONCLICK", "bottone cliccato");
    Toast t = Toast.makeText(cntx, "OK", Toast.LENGTH_LONG);
    t.show();
}

Теперь, когда я пытаюсь запустить его, приложение вылетает на моем телефоне, и logcat сообщает

не удалось создать экземпляр информации о компоненте активности в mainactivity.

что случилось?

журнал информации logcat

02-07 11:43:54.887: E/AndroidRuntime(9048): НЕИСПРАВНОЕ ИСКЛЮЧЕНИЕ: main 02-07 11:43:54.887: E/AndroidRuntime(9048): java.lang.RuntimeException: невозможно создать экземпляр активности ComponentInfo{com. Например. -07 11:43:54.887: E/AndroidRuntime(9048): в android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230) 02-07 11:43:54.887: E/AndroidRuntime(9048): в android.app .ActivityThread.access$600(ActivityThread.java:141) 02-07 11:43:54.887: E/AndroidRuntime(9048): в android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234) 02-07 11: 43:54.887: E/AndroidRuntime(9048): в android.os.Handler.dispatchMessage(Handler.java:99) 02-07 11:43:54.887: E/AndroidRuntime(9048): в android.os.Looper.loop (Looper.java:137) 02-07 11:43: 54.887: E/AndroidRuntime(9048): в android.app.ActivityThread.main(ActivityThread.java:5039) 02-07 11:43:54.887: E/AndroidRuntime(9048): в java.lang.reflect.Method.invokeNative (Собственный метод) 02-07 11:43:54.887: E/AndroidRuntime(9048): в java.lang.reflect.Method.invoke(Method.java:511) 02-07 11:43:54.887: E/AndroidRuntime( 9048): в com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793) 02-07 11:43:54.887: E/AndroidRuntime(9048): в com.android.internal.os.ZygoteInit .main(ZygoteInit.java:560) 02-07 11:43:54.887: E/AndroidRuntime(9048): at dalvik.system.NativeStart.main(собственный метод) 02-07 11:43:54.887: E/AndroidRuntime( 9048): Вызвано: java.lang.NullPointerException 02-07 11:43:54.887: E/AndroidRuntime(9048): at android.content.ContextWrapper.getApplicationContext(ContextWrapper.java:109) 02-07 11:43:54.887 : E/AndroidRuntime(9048): at com.example.buttoneventlistener.MainActivity.(MainActivity.java:13) 02-07 1 1:43:54.887: E/AndroidRuntime(9048): в java.lang.Class.newInstanceImpl(собственный метод) 02-07 11:43:54.887: E/AndroidRuntime(9048): в java.lang.Class.newInstance( Class.java:1319) 02-07 11:43:54.887: E/AndroidRuntime(9048): в android.app.Instrumentation.newActivity(Instrumentation.java:1054) 02-07 11:43:54.887: E/AndroidRuntime( 9048): в android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097) 02-07 11:43:54.887: E/AndroidRuntime(9048): ... еще 11


person giozh    schedule 07.02.2013    source источник
comment
Можете ли вы опубликовать полную трассировку стека?   -  person Shashank Kadne    schedule 07.02.2013
comment
@ShashankKadne добавил журнал   -  person giozh    schedule 07.02.2013
comment
Это похоже на старую бревенчатую кошку. Можете ли вы вставить логарифм после внесения изменений, предложенных в ответе ниже?   -  person Shashank Kadne    schedule 07.02.2013


Ответы (2)


переместите setContentView(R.layout.activity_main); строку перед доступом к кнопке из пользовательского интерфейса как:

public class MainActivity extends Activity {

private  Context main_context; 

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
     setContentView(R.layout.activity_main);  //<< set Activity layout here

    main_context = this.getApplicationContext(); 
    Button b = (Button)findViewById(R.id.bottone);
    Log.i("AAAAAAAAAAAA", "1");

    OnClickListener l = new MyClickListener(this);
    b.setOnClickListener(l);
    Log.i("AAAAAAAAAAAA", "2");



}
person ρяσѕρєя K    schedule 07.02.2013
comment
@giozh: почему это не решает текущую проблему, это одна проблема, которую я нашел в вашем коде, возможно, другие проблемы все еще присутствуют. просто опубликуйте результат logcat - person ρяσѕρєя K; 07.02.2013
comment
@giozh : а также изменить строку private final Context main_context = this.getApplicationContext(); в соответствии с моим ответом - person ρяσѕρєя K; 07.02.2013

Редактировать:

изменить R.button.bottone на R.id.bottone и android:id ="@+button/bottone" на android:id ="@+id/bottone"

setContentView перед получением объекта кнопки, в противном случае объект кнопки возвращает null, Accessing, но вызовет исключение NullPointerException. setContentView(R.layout.activity_main); поместите это перед созданием кнопки

person Pragnani    schedule 07.02.2013
comment
@giozh измените R.button.bottone на R.id.bottone и android:id =@+button/bottone на android:id =@+id/bottone - person Pragnani; 07.02.2013
comment
@Pragnani: +10 за хороший улов! - person ρяσѕρєя K; 07.02.2013