所以我在我的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)
但这不太理想,因为那时我可以传递任何我想要的东西,也许不是活动的东西......毕竟这是Java,而不是Ruby)。此外,如果它只允许我只通过一堂课......它到底有什么好处?
那么我该如何做到这一点呢?
你可以这样写通配符:
protected void loadNextActivity(Class<? extends Activity> activityToLoad)
使用Class<?>
不是很好的做法。您不会知道类令牌的确切类型。嗯,尝试为您的方法定义全局行为,就像我上面写的那样使用通配符。
顺便说一下,请确保您添加到Manifest.xml
文件中的每个活动,例如:
<activity android:name=".com.bla.bla.YourOtherActivity" />
您的代码注释说"如果我在这里这样做,我会收到错误。 您遇到哪些错误? 是不是你有一个无效的上下文作为 getIntent() 的参数? 或者 startActivity() 无效? 可能的原因是 onPostExecute() 是从内部类调用的,而不是活动本身。
试试这个:
onPostExecute(Void result) {
Intent intent = new Intent(SomeCoolActivity.this, NextActivity.class);
startActivity(intent);
}
说明:您不想传递活动,也不想将它们保存在变量中。 如果这样做,则会泄漏整个视图层次结构,并且会很快耗尽RAM。