在我的应用中,我在大约5个不同的屏幕之间导航,每个屏幕都在自己的activity
中。几乎任何activity
都可以从任何其他activity
调用,所以我正在尝试构建一个帮助文件来管理intents
,以便我没有冗余代码。
我使用public static
方法构建了一个帮助文件,并在调用这些方法时传递活动context
和所有必需的数据。这似乎在我的设备(三星Galaxy S5)上工作正常,但Android Studio建议在我的帮助文件中使用我的意图AtomicReference。
您能否帮助我了解这些应该AtomicReference<Intent>
的原因和原因?{1}}
另外,将context
传递给帮助文件以进行这些调用是否合适?
ActivityHelper文件:
public class ActivityHelper {
private ActivityHelper() {}
public static void startAddNewMealActivity(Context context) {
Intent newMealIntent = new Intent(context, MealEditActivity.class);
context.startActivity(newMealIntent);
}
public static void startMealListActivity(Context context) {
Intent intent = new Intent(context, MealListActivity.class);
context.startActivity(intent);
}
public static void startEditMealActivity(Context context, FBMeal meal, String mealFBKey) {
Intent intent = new Intent(context, MealEditActivity.class);
intent.putExtra(Constants.INTENT_FB_KEY_EXTRA_TAG, mealFBKey);
intent.putExtra(Constants.INTENT_MEAL_EXTRA_TAG, meal);
context.startActivity(intent);
}
public static void startEditLastMealActivity(final Context context) {
FBHelper.getQueryForMostRecentMeal().addListenerForSingleValueEvent(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
if (FBHelper.isExistingDataSnapshop(dataSnapshot)) {
for (DataSnapshot snapshot : dataSnapshot.getChildren()) {
FBMeal selectedMeal = snapshot.getValue(FBMeal.class);
String selectedMealId = snapshot.getKey();
startEditMealActivity(context, selectedMeal, selectedMealId);
}
} else {
Utils.showToastFromStringResource(R.string.no_meals, context);
}
}
@Override
public void onCancelled(DatabaseError databaseError) {
Utils.showToastFromStringResource(R.string.error_getting_meal, context);
}
});
}
}
从AppCompatActivity中的菜单调用帮助文件的示例:
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.edit_meal_menu:
ActivityHelper.startEditMealActivity(this, meal, mealFBKey);
return true;
case R.id.edit_last_entry_menu:
ActivityHelper.startEditLastMealActivity(this);
return true;
case R.id.about_menu:
DialogFragment newFragment = AboutDialog.newInstance();
newFragment.show(getFragmentManager(), "about");
default:
return super.onOptionsItemSelected(item);
}
}
答案 0 :(得分:1)
我完全不明白为什么您需要在AtomicReference
方法中使用static
。
另一种方法是创建一个扩展BaseActivity
的{{1}}类,并包含所有辅助方法。然后,您的所有活动都应扩展AppCompatActivity
。在这种情况下,您不需要将BaseActivity
传递给所有这些辅助方法,因为辅助方法是非静态的,只能将Context
用作this
。