Почему «dumpsys Activity top» выводит «фрагмент» в своем выводе, пока я не использовал фрагмент? - PullRequest
0 голосов
/ 26 марта 2020

SecondActivity имеет только простую компоновку, которая установлена ​​как ContentView в его onCreate() методе:

protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_second);
}

И activity_second.xml:

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".SecondActivity" />

Но когда я использую dumpsys для вывода верхней активности, в выводе выводится неизвестный Fragment («ReportFragment»):

$ adb shell dumpsys activity top
TASK xxx.lifecycleapplication id=4
  ACTIVITY xxx.lifecycleapplication/.SecondActivity 538274ac pid=1519
    Local Activity 5368915c State:
      mResumed=true mStopped=false mFinished=false
      mLoadersStarted=true
      mChangingConfigurations=false
      mCurrentConfig={1.0 310mcc270mnc en_US sw384dp w384dp h567dp nrml port finger qwerty/v/v dpad/v s.5}
    Active Fragments in 536891f0:
      #0: ReportFragment{5369f99c #0 androidx.lifecycle.LifecycleDispatcher.report_fragment_tag}
        mFragmentId=#0 mContainerId=#0 mTag=androidx.lifecycle.LifecycleDispatcher.report_fragment_tag
        mState=5 mIndex=0 mWho=android:fragment:0 mBackStackNesting=0
        mAdded=true mRemoving=false mResumed=true mFromLayout=false mInLayout=false
        mHidden=false mDetached=false mMenuVisible=true mHasMenu=false
        mRetainInstance=false mRetaining=false mUserVisibleHint=true
        mFragmentManager=FragmentManager{536891f0 in SecondActivity{5368915c}}
        mActivity=xxx.lifecycleapplication.SecondActivity@5368915c
    Added Fragments:
      #0: ReportFragment{5369f99c #0 androidx.lifecycle.LifecycleDispatcher.report_fragment_tag}
    FragmentManager misc state:
      mCurState=5 mStateSaved=false mDestroyed=false
    Local FragmentActivity 5368915c State:
      mCreated=true mResumed=true mStopped=false    FragmentManager misc state:
      mHost=androidx.fragment.app.FragmentActivity$HostCallbacks@5368b814
      mContainer=androidx.fragment.app.FragmentActivity$HostCallbacks@5368b814
      mCurState=4 mStateSaved=false mStopped=false mDestroyed=false

Почему на выходе отображается ReportFragment в «Активных фрагментах» и « Добавлены фрагменты "пока я не пользуюсь Fragment?

1 Ответ

0 голосов
/ 26 марта 2020

Эта строка является подсказкой:

mTag=androidx.lifecycle.LifecycleDispatcher.report_fragment_tag

ReportFragment - это деталь реализации, используемая lifecycle-process и ProcessLifecycleOwner для отслеживание активности вашего приложения. До API 29 он использует Фрагмент инфраструктуры для отслеживания этого во всех действиях (будь то AppCompatActivity или обычные Activity подклассы).

...