所以我在我的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。而且,如果它只允许我传入一个类......那究竟有什么好处呢?
那我该怎么做呢?
答案 0 :(得分:5)
您可以编写通配符,如:
protected void loadNextActivity(Class<? extends Activity> activityToLoad)
使用Class<?>
是不好的做法。您不会知道类令牌的确切类型。嗯,尝试使用通配符为我的方法定义全局行为,就像我上面写的那样。
顺便说一下,确保您添加到Manifest.xml
文件中的每个活动,例如:
<activity android:name=".com.bla.bla.YourOtherActivity" />
答案 1 :(得分:0)
您的代码评论说“如果我在这里这样做,我会收到错误。”你得到了什么错误?你是否有一个无效的上下文作为getIntent()的参数?或者startActivity()无效?可能的原因是onPostExecute()是从内部类调用的,而不是Activity本身。
试试这个:
onPostExecute(Void result) {
Intent intent = new Intent(SomeCoolActivity.this, NextActivity.class);
startActivity(intent);
}
答案 2 :(得分:0)
旁注:您不想传递活动,从不想要将它们保存在变量中。如果你这样做,你就会泄漏整个视图层次结构,并且会快速地使用ram。