NullPointerException при вызове самописного класса - PullRequest
4 голосов
/ 15 мая 2011

Я звоню из одного класса в другой класс. Я могу устанавливать значения и получать значения при создании объекта (см. Журнал), но существует множество методов, которые выдают исключение (см. Также журнал). Например, поджаривание чего-нибудь. Если я помещаю код в тост в оригинальном классе, он работает, если я пытаюсь вызвать его, он не работает. В моем коде ниже эти вещи, которые не работают, закомментированы (// code...).

Вот главный класс:

public class Main extends Activity {
private MyMenu myMenu;
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    myMenu = new MyMenu ();

    myMenu.setMyMenu (3, "some text");
    int number = myMenu.getMyMenuNumber();
    String text = myMenu.getMyMenuString();

    Log.d("LOG", "number is " + number + " and text is '" + text + "'.");

    try {
        Log.d ("LOG", "startMain error");
        //myMenu.startMain();
        startActivity(new Intent (this, Page1.class));
    } catch (NullPointerException e) {
        e.printStackTrace();
    }

    try {
        Log.d ("LOG", "putToast error");
        //myMenu.putToast();
        Toast.makeText(
                this, 
                "This is a toast", 
                Toast.LENGTH_LONG)
                .show();
    } catch (NullPointerException e) {
        e.printStackTrace();
    }
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    try {
        Log.d ("LOG", "inflateMenu error");
        //myMenu.inflateMenu(menu);
        getMenuInflater().inflate(R.menu.menu, menu);

    } catch (NullPointerException e) {
        e.printStackTrace();
    }
    return super.onCreateOptionsMenu(menu);
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    try {
        Log.d ("LOG", "isOptionsButtonClicked error");
        //myMenu.isOptionsButtonClicked(item);
        switch (item.getItemId()) {     
        case R.id.feedback:
            startActivity(new Intent (this, Page1.class));
            break;
        case R.id.more_information:
            startActivity(new Intent (this, Page1.class));
            break;
        }
    } catch (NullPointerException e) {
        e.printStackTrace();
    }
    return super.onOptionsItemSelected(item);
}
}

и это MyMenu.class:

public class MyMenu extends Activity {
    int number;
    String text;

public MyMenu() {

}
public void setMyMenu (int number, String text) {
    this.number = number;
    this.text = text;
}
public int getMyMenuNumber () {
    return number;
}
public String getMyMenuString () {
    return text;
}

public void startMain () {
    startActivity(new Intent (this, Page1.class));
}

public void inflateMenu (Menu menu) {
    getMenuInflater().inflate(R.menu.menu, menu);
}
public void putToast () {
    Toast.makeText(
            this, 
            "This is a toast", 
            Toast.LENGTH_LONG)
    .show();
}
public void isOptionsButtonClicked (MenuItem item) {
    switch (item.getItemId()) {     
    case R.id.feedback:
        startActivity(new Intent (this, Page1.class));
        break;
    case R.id.more_information:
        startActivity(new Intent (this, Page1.class));
        break;
    }
}
}

Еще раз подчеркну, что все в Main.class работает отлично, но вызов других классов не работает.

UPDATE

Вот части Log / StackTrace:

05-15 08:13:13.502: DEBUG/LOG(546): inflateMenu error
05-15 08:13:13.513: WARN/System.err(546): java.lang.NullPointerException
05-15 08:13:13.522: WARN/System.err(546):     at android.content.ContextWrapper.getResources(ContextWrapper.java:80)
05-15 08:13:13.522: WARN/System.err(546):     at android.view.MenuInflater.inflate(MenuInflater.java:77)
05-15 08:13:13.522: WARN/System.err(546):     at com.test.MyMenu.inflateMenu(MyMenu.java:34)
05-15 08:13:13.533: WARN/System.err(546):     at com.test.Main.onCreateOptionsMenu(Main.java:52)
05-15 08:13:13.542: WARN/System.err(546):     at android.app.Activity.onCreatePanelMenu(Activity.java:2123)
05-15 08:13:13.542: WARN/System.err(546):     at com.android.internal.policy.impl.PhoneWindow.preparePanel(PhoneWindow.java:305)
05-15 08:13:13.542: WARN/System.err(546):     at com.android.internal.policy.impl.PhoneWindow.onKeyDownPanel(PhoneWindow.java:550)
05-15 08:13:13.582: WARN/System.err(546):     at com.android.internal.policy.impl.PhoneWindow.onKeyDown(PhoneWindow.java:1192)
05-15 08:13:13.582: WARN/System.err(546):     at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchKeyEvent(PhoneWindow.java:1636)
05-15 08:13:13.582: WARN/System.err(546):     at android.view.ViewRoot.deliverKeyEventToViewHierarchy(ViewRoot.java:2368)
05-15 08:13:13.582: WARN/System.err(546):     at android.view.ViewRoot.handleFinishedEvent(ViewRoot.java:2338)
05-15 08:13:13.582: WARN/System.err(546):     at android.view.ViewRoot.handleMessage(ViewRoot.java:1641)
05-15 08:13:13.582: WARN/System.err(546):     at android.os.Handler.dispatchMessage(Handler.java:99)
05-15 08:13:13.592: WARN/System.err(546):     at android.os.Looper.loop(Looper.java:123)
05-15 08:13:13.592: WARN/System.err(546):     at android.app.ActivityThread.main(ActivityThread.java:4363)
05-15 08:13:13.602: WARN/System.err(546):     at     java.lang.reflect.Method.invokeNative(Native Method)
05-15 08:13:13.602: WARN/System.err(546):     at java.lang.reflect.Method.invoke(Method.java:521)
05-15 08:13:13.602: WARN/System.err(546):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
05-15 08:13:13.602: WARN/System.err(546):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
05-15 08:13:13.602: WARN/System.err(546):     at dalvik.system.NativeStart.main(Native Method)

и

05-15 08:13:03.592: DEBUG/LOG(546): putToast error
05-15 08:13:03.612: WARN/System.err(546): java.lang.NullPointerException
05-15 08:13:03.621: WARN/System.err(546):     at android.content.ContextWrapper.getResources(ContextWrapper.java:80)
05-15 08:13:03.633: WARN/System.err(546):     at android.widget.Toast.<init>(Toast.java:89)
05-15 08:13:03.633: WARN/System.err(546):     at android.widget.Toast.makeText(Toast.java:231)
05-15 08:13:03.633: WARN/System.err(546):     at com.test.MyMenu.putToast(MyMenu.java:37)
05-15 08:13:03.641: WARN/System.err(546):     at com.test.Main.onCreate(Main.java:37)
05-15 08:13:03.641: WARN/System.err(546):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
05-15 08:13:03.652: WARN/System.err(546):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2459)
05-15 08:13:03.652: WARN/System.err(546):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2512)
05-15 08:13:03.652: WARN/System.err(546):     at android.app.ActivityThread.access$2200(ActivityThread.java:119)
05-15 08:13:03.661: WARN/System.err(546):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1863)
05-15 08:13:03.661: WARN/System.err(546):     at android.os.Handler.dispatchMessage(Handler.java:99)
05-15 08:13:03.671: WARN/System.err(546):     at    android.os.Looper.loop(Looper.java:123)
05-15 08:13:03.671: WARN/System.err(546):     at android.app.ActivityThread.main(ActivityThread.java:4363)
05-15 08:13:03.671: WARN/System.err(546):     at java.lang.reflect.Method.invokeNative(Native Method)
05-15 08:13:03.683: WARN/System.err(546):     at java.lang.reflect.Method.invoke(Method.java:521)
05-15 08:13:03.683: WARN/System.err(546):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
05-15 08:13:03.691: WARN/System.err(546):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
05-15 08:13:03.691: WARN/System.err(546):     at dalvik.system.NativeStart.main(Native Method)

надеюсь, это поможет!

UDATE 2

Вот запрошенный Page1.class. Но опять же все работает нормально, когда я не использую MyMenu.class.

public class Page1 extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.page1);
}

}

Кроме того, вы можете скачать проект Android с Microsoft Live / Windows Live Skydrive: http://cid -f45ce92851885387.office.live.com / browse.aspx / Stackoverflow

1 Ответ

0 голосов
/ 15 мая 2011

Не могу понять, почему вы делегируете этот метод ниже другому занятию:

public void startMain () {
   startActivity(new Intent (this, Page1.class)); // this <- here is problem
}

Полагаю, это из-за плохого дизайна. Не делай этого. Используйте Intents. Передача данных между действиями в Intents in Bundles. В вашем случае вы не передали Context в MyMenu Activity. У MyMenu нет экземпляра Application Context, поэтому вы получаете NPE.

ответ на комментарий:
Конечно, вы можете использовать статический метод startMain. Но обратите внимание на то, что «это» в новом намерении (это, Page1.class). Вы должны передать Контекст Деятельности, с которой вы начинаете новую Активность.

public static void startMain (Activity context) {
   context.startActivity(new Intent (context, Page1.class));
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...