7

所以我在我的 Android 应用程序中到处传递活动和意图来处理线程(我确信有一个更好的范例,因为我的代码开始变得烦人的意大利面条式 - 通常是我的标志没有做正确的事)。

但无论如何,我正在尝试做这样的事情:

public class SomeCoolActivity extends Activity {
    private class DoSomeTaskThatInvolvesEitherTheNetworkOrASleepStatementWithoutScrewingUpTheUiThread extends AsyncTask<Void, Void, Void> {
        @Override
        protected Void doInBackground(Void... params) {
            // Do something useful on a non-UI thread...
            return null;
        }

        @Override
        protected void onPostExecute(Void result) {
            // Now that's done, I need to progress to the next activity. If I do that here,
            // I will get errors. So instead, I will call a method on my parent activity class:
            loadNextActivity(NextActivity.class);
        }
    }

    protected void loadNextActivity(Class<Activity> activityToLoad) {
        startActivity(new Intent(this, activityToLoad));
    }
}

但这不起作用,因为它告诉我有一个错误,即

NextActivity.class

不是活动。是的,显然它不是完全相同的类,但是人们希望我能够传入任何派生自 Activity 的类(包括 NextActivity),但不能传入任何不能传入的类(如果我定义 loadNextActivity 它实际上可以正常工作作为

protected void loadNextActivity(Class<?> activityToLoad)

但这不太理想,因为那时我可以传递任何我想要的东西,也许不是 Activity 的东西……毕竟这是 Java,而不是 Ruby)。而且,如果它只允许我通过一门课……这​​到底有什么好处?

那么我该如何进行这项工作呢?

4

3 回答 3

5

你可以这样写通配符:

protected void loadNextActivity(Class<? extends Activity> activityToLoad)

使用它不是一个好习惯Class<?>。您不会知道类令牌的确切类型。嗯,尝试使用通配符为您的方法定义全局行为,就像我上面写的那样。

顺便说一句,请确保您添加到Manifest.xml文件中的每个活动,例如:

<activity android:name=".com.bla.bla.YourOtherActivity" />
于 2012-11-29T18:07:33.597 回答
0

您的代码注释说“如果我在这里这样做,我会得到错误。”。你得到什么错误?是不是你有一个无效的上下文作为 getIntent() 的参数?或者 startActivity() 无效?可能的原因是 onPostExecute() 是从内部类调用的,而不是 Activity 本身。

试试这个:

  onPostExecute(Void result) {
    Intent intent = new Intent(SomeCoolActivity.this, NextActivity.class);
    startActivity(intent);
  }
于 2012-11-29T18:37:37.820 回答
0

附带说明:您不想传递活动,不想将它们保存在变量中。如果你这样做,你会泄漏整个视图层次结构,并且会很快用完 ram。

于 2012-11-29T18:44:48.320 回答