Фрагмент onStop () вызывается сразу после onStart () - ПОЧЕМУ? - PullRequest
9 голосов
/ 28 сентября 2011

У меня странная проблема с моим приложением -

A имеет операцию фрагмента, которая содержит фрагмент - этот фрагмент запускает AsyncTask onCreate () и отменяет AsyncTask onStop ().Моя проблема возникает из-за того, что, хотя мой фрагмент продолжает работать и не скрыт, он вызывается onStop () почти сразу после вызова onCreate ().

Кто-нибудь знает, как отследить, почему это происходит?

09-28 11:41:56.785: VERBOSE/SearchFragment1(924): onCreate()
09-28 11:41:56.796: VERBOSE/SearchFragment1(924): onStop()

РЕДАКТИРОВАТЬ

Я удалил код из фрагмента, и я все еще совершенно сбит с толку - проблема сохраняется!Я добавил еще несколько строк регистрации:

09-28 14:09:00.242: VERBOSE/SearchResultsFragment1(1789): onAttach()
09-28 14:09:00.242: VERBOSE/SearchResultsFragment1(1789): onCreate()
09-28 14:09:00.242: VERBOSE/SearchResultsFragment1(1789): onCreateView()
09-28 14:09:00.242: VERBOSE/SearchResultsFragment1(1789): onActivityCreated()
09-28 14:09:00.242: VERBOSE/SearchResultsFragment1(1789): onStart()
09-28 14:09:00.246: VERBOSE/SearchResultsFragment1(1789): onStop()
09-28 14:09:00.246: VERBOSE/SearchResultsFragment1(1789): onStart()
09-28 14:09:00.246: VERBOSE/SearchResultsFragment1(1789): onResume()

Вышеуказанное поведение ... сбивает с толку.Код, используемый в Деятельности, выглядит следующим образом:

if(savedInstanceState == null) 
{
    try {
        FragmentTransaction transaction= getSupportFragmentManager().beginTransaction();    
        Fragment currentFragment= (Fragment)Class.forName(getIntent().getAction()).newInstance();
        transaction.replace(R.id.singlePane, currentFragment);  
        transaction.commit();
    } catch ...

Это фрагмент, который стоит во время отладки:

private static final boolean LOGGING_ENABLED = true;
private static int global_creation_count = 0;
private int local_count = global_creation_count;

@Override
public void onAttach(Activity activity) {   
    super.onAttach(activity);
    if(LOGGING_ENABLED) Log.v(this.getClass().getSimpleName() + local_count, "onAttach()");
}

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    global_creation_count+=1;       
    if(LOGGING_ENABLED) Log.v(this.getClass().getSimpleName() + local_count, "onCreate()");
}

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
        Bundle savedInstanceState) {
    if(LOGGING_ENABLED) Log.v(this.getClass().getSimpleName() + local_count, "onCreateView()");
    return super.onCreateView(inflater, container, savedInstanceState);     
}

@Override
public void onActivityCreated(Bundle savedInstanceState) {
    super.onActivityCreated(savedInstanceState);
    if(LOGGING_ENABLED) Log.v(this.getClass().getSimpleName() + local_count, 
    "onActivityCreated()");
}

@Override
public void onStart() {
    super.onStart();
    if(LOGGING_ENABLED) Log.v(this.getClass().getSimpleName() + local_count, "onStart()");
}       

@Override
public void onResume() {
    super.onResume();
    if(LOGGING_ENABLED) Log.v(this.getClass().getSimpleName() + local_count, "onResume()");
}

// Fragment is active

@Override
public void onPause() {
    super.onPause();
    if(LOGGING_ENABLED) Log.v(this.getClass().getSimpleName() + local_count, "onPause()");
}   

@Override
public void onStop() {
    super.onStop();
    if(LOGGING_ENABLED) Log.v(this.getClass().getSimpleName() + local_count, "onStop()");
}   

@Override
public void onDestroyView() {
    super.onDestroyView();
    if(LOGGING_ENABLED) Log.v(this.getClass().getSimpleName() + local_count, "onDestroyView()");
}

@Override
public void onDestroy() {   
    super.onDestroy();
    if(LOGGING_ENABLED) Log.v(this.getClass().getSimpleName() + local_count, "onDestroy()");
}

@Override
public void onDetach() {    
    super.onDetach();
    if(LOGGING_ENABLED) Log.v(this.getClass().getSimpleName() + local_count, "onDetach()");
}   

EDIT2

Из кода кажется, что onStop () вызывается сразу после onStart ().Я пытался увидеть, вызывается ли он одновременно с onStart (), добавив Thread.sleep (1000) в onCreateView ().Вывод тот же - что заставляет меня поверить, что onStop () вызывается / вызывается непосредственно из процесса создания фрагмента.

EDIT3

Stacktrace при взломе onStop (): enter image description here

Я попытаюсь присоединить исходный код и пошагово выяснить, в чем проблема.

1 Ответ

8 голосов
/ 28 сентября 2011

Все еще не знаю, что он пытался сделать ... Я выяснил, где взять исходный код для класса, вызванного onStop (), и обнаружил, что исходный код для android-support-v4.jar поставляется в упаковке. вместе с банкой в ​​SDK.

После подключения этого источника я вскоре обнаружил, что он не синхронизирован и что мой android-support-v4.jar сильно отличается от того, который поставляется с текущей версией SDK.

Замена jar на тот, который поставляется вместе с SDK, решает проблему мгновенно, и onStop () не вызывается после onStart (). Не уверен, какая ошибка вызывала это, но последняя версия, кажется, исправляет это довольно легко.

...