Я только что начал разрабатывать простое приложение Android, в то время как я все еще изучаю платформу.
Я использую Eclipse IDE с плагином ADT 0.9.6.
Я должен знать, возможно ли просмотреть Activity
стек, который связан с Задачей?
Есть ли какой-либо путь через инструмент DDMS или через какую-либо другую технику?
По существу то, в чем я нуждаюсь, должно смочь видеть действие стека задачи удостовериться, что приложение ведет себя как ожидалось.
Я знаю, что возможно управлять поведением задачи в некоторой степени с помощью флагов в Intent
возразите и через некоторые атрибуты <activity>
элемент.
Однако было бы хорошо иметь своего рода инструмент - особенно в режиме отладки или так - который позволит разработчикам видеть Activity
прямой стек.
В командной строке вы можете использовать: adb shell dumpsys activity
Это просит диспетчер операций распечатать дамп своего текущего состояния . Первая часть - это полная история активности, организованная по задачам. После этого также будет напечатано много материала, поэтому вам может потребоваться немного прокрутить вверх, чтобы найти то, что вы хотите.
Вот пример его вывода (точное содержание различается в зависимости от версии платформы), показывающий, что главной задачей является контакт с двумя действиями, а за ним - программа запуска с одним действием:
Activities in Current Activity Manager State: * TaskRecord{44d07218 #4 A android.task.contacts} clearOnBackground=true numActivities=2 rootWasReset=true affinity=android.task.contacts intent={act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] flg=0x10600000 cmp=com.android.contacts/.DialtactsActivity bnds=[125,640][235,758]} origActivity=com.android.contacts/.DialtactsContactsEntryActivity realActivity=com.android.contacts/.DialtactsActivity lastActiveTime=288203177 (inactive for 14s) * Hist #8: HistoryRecord{44b87a30 com.android.contacts/.ViewContactActivity} packageName=com.android.contacts processName=android.process.acore launchedFromUid=10004 app=ProcessRecord{44c4f348 1168:android.process.acore/10004} Intent { act=android.intent.action.VIEW dat=content://com.android.contacts/contacts/lookup/144i148.144i461a29500afc8eeb/1927 cmp=com.android.contacts/.ViewContactActivity } frontOfTask=false task=TaskRecord{44d07218 #4 A android.task.contacts} taskAffinity=android.task.contacts realActivity=com.android.contacts/.ViewContactActivity base=/system/app/Contacts.apk/system/app/Contacts.apk data=/data/data/com.android.contacts labelRes=0x7f090012 icon=0x7f02006b theme=0x7f0e0004 stateNotNeeded=false componentSpecified=false isHomeActivity=false configuration={ scale=1.0 imsi=310/4 loc=en_US touch=3 keys=2/1/2 nav=2/2 orien=1 layout=34} resultTo=HistoryRecord{44d174d0 com.android.contacts/.DialtactsContactsEntryActivity} resultWho=favorites resultCode=2 launchFailed=false haveState=false icicle=null state=RESUMED stopped=false delayedResume=false finishing=false keysPaused=false inHistory=true persistent=false launchMode=0 fullscreen=true visible=true frozenBeforeDestroy=false thumbnailNeeded=false idle=true waitingVisible=false nowVisible=true * Hist #7: HistoryRecord{44d174d0 com.android.contacts/.DialtactsContactsEntryActivity} packageName=com.android.contacts processName=android.process.acore launchedFromUid=10004 app=ProcessRecord{44c4f348 1168:android.process.acore/10004} Intent { act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] flg=0x10200000 cmp=com.android.contacts/.DialtactsContactsEntryActivity bnds=[125,640][235,758] } frontOfTask=true task=TaskRecord{44d07218 #4 A android.task.contacts} taskAffinity=android.task.contacts realActivity=com.android.contacts/.DialtactsActivity base=/system/app/Contacts.apk/system/app/Contacts.apk data=/data/data/com.android.contacts labelRes=0x7f090007 icon=0x7f02006b theme=0x7f0e0000 stateNotNeeded=false componentSpecified=true isHomeActivity=false configuration={ scale=1.0 imsi=310/4 loc=en_US touch=3 keys=2/1/2 nav=2/2 orien=1 layout=34} launchFailed=false haveState=true icicle=Bundle[mParcelledData.dataSize=4196] state=STOPPED stopped=true delayedResume=false finishing=false keysPaused=false inHistory=true persistent=false launchMode=2 fullscreen=true visible=false frozenBeforeDestroy=false thumbnailNeeded=false idle=true * TaskRecord{44c4ee90 #2 A com.android.launcher} clearOnBackground=true numActivities=1 rootWasReset=true affinity=com.android.launcher intent={act=android.intent.action.MAIN cat=[android.intent.category.HOME] flg=0x10600000 cmp=com.android.launcher/.Launcher} realActivity=com.android.launcher/.Launcher lastActiveTime=214734838 (inactive for 73483s) * Hist #6: HistoryRecord{44c4d988 com.android.launcher/.Launcher} packageName=com.android.launcher processName=android.process.acore launchedFromUid=0 app=ProcessRecord{44c4f348 1168:android.process.acore/10004} Intent { act=android.intent.action.MAIN cat=[android.intent.category.HOME] flg=0x10000000 cmp=com.android.launcher/.Launcher } frontOfTask=true task=TaskRecord{44c4ee90 #2 A com.android.launcher} taskAffinity=com.android.launcher realActivity=com.android.launcher/.Launcher base=/system/app/Launcher.apk/system/app/Launcher.apk data=/data/data/com.android.launcher labelRes=0x7f0a0000 icon=0x7f020015 theme=0x103005f stateNotNeeded=true componentSpecified=false isHomeActivity=true configuration={ scale=1.0 imsi=310/4 loc=en_US touch=3 keys=2/1/2 nav=2/2 orien=1 layout=34} launchFailed=false haveState=true icicle=Bundle[mParcelledData.dataSize=5964] state=STOPPED stopped=true delayedResume=false finishing=false keysPaused=false inHistory=true persistent=false launchMode=2 fullscreen=true visible=false frozenBeforeDestroy=false thumbnailNeeded=false idle=true