真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

AndroidApp調(diào)試的命令有哪些

本篇內(nèi)容主要講解“Android App調(diào)試的命令有哪些”,感興趣的朋友不妨來看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“Android App調(diào)試的命令有哪些”吧!

成都創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站建設(shè)、網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的防城港網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

1.logcat命令

這個(gè)命令最簡(jiǎn)單常用,可查看幫助,我不多說,如果需要打印時(shí)間,加參數(shù)-v time

adb logcat -v time

2.bugreport命令

這個(gè)命令也非常簡(jiǎn)單,但是在實(shí)際應(yīng)用中非常有用,會(huì)有從開機(jī)之后詳細(xì)的dumpsys,dumpstate和logcat信息,是一份完整的日志記錄。對(duì)分析用戶行為,異常信息,系統(tǒng)狀態(tài)有很大的參考作用。一般我們會(huì)把bugreport導(dǎo)出到電腦上分析。

1adb bugreport > xxx.log

我再次強(qiáng)調(diào),bugreport里面包含豐富的系統(tǒng)和用戶信息,它是其他很多命令輸出的結(jié)果的記錄,非常有用。

3.dumpsys命令

這個(gè)查看系統(tǒng)信息,用的還是比較多的.

dumpsys [options]

meminfo 顯示內(nèi)存信息

cpuinfo 顯示CPU信息

account 顯示accounts信息

activity 顯示所有的activities的信息

window 顯示鍵盤,窗口和它們的關(guān)系

wifi 顯示wifi信息

例如查看某個(gè)程序內(nèi)存信息:

#查看應(yīng)用com.tianxia.test的內(nèi)存使用情況

adb shell dumpsys meminfo com.tianxia.test

效果圖如下:

Android App調(diào)試的命令有哪些

里面的信息很有價(jià)值,尤其對(duì)于分析內(nèi)存泄露,內(nèi)存溢出都有極大的作用。

4.top命令

這個(gè)查看cpu信息太方便了。

1top -m 5 -t

我們看看效果圖,其中按cpu大小列出5個(gè)進(jìn)程列表。

Android App調(diào)試的命令有哪些

com.tianxia.test的cpu過高,會(huì)導(dǎo)致手機(jī)發(fā)燙。同時(shí)利用這個(gè)信息,可以監(jiān)控應(yīng)用cpu的使用,以調(diào)整優(yōu)化代碼。

5.配置文件local.prop

目前網(wǎng)上沒有查到local.prop的配置使用,工作中本人只使用過如下:

1log.tag.SQLiteStatements=VERBOSE log.tag.SQLiteTime=VERBOSE

把上述文本加到/data/local.prop中,如果沒有這個(gè)文件自行創(chuàng)建。然后重啟手機(jī),就能看到每個(gè)應(yīng)用詳細(xì)的查詢數(shù)據(jù)庫的sql語句信息,對(duì)于調(diào)試數(shù)據(jù)庫,分析和優(yōu)化數(shù)據(jù)庫sql異常非常有用。

6.分析手機(jī)發(fā)燙

下面我們來實(shí)踐一個(gè)例子,手機(jī)發(fā)燙太厲害,怎么找出問題?

首先我們寫一個(gè)程序com.tianxia.test,死循環(huán),核心代碼如下:

8@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.main);

while(true) {

System.currentTimeMillis();

}

}

這個(gè)應(yīng)用打開后會(huì)一直獲取系統(tǒng)時(shí)間,因?yàn)樵谥骶€程,肯定導(dǎo)致應(yīng)用ANR,也會(huì)一直浪費(fèi)系統(tǒng)cpu,手機(jī)發(fā)熱,我們運(yùn)行它。

假設(shè)我們不知道上述代碼,我們來找到這個(gè)問題:

(1).找到發(fā)燙的應(yīng)用。

使用top命令:

1top -m 5 -t

Android App調(diào)試的命令有哪些

一看是com.tianxia.test占用85%的cpu,原來是這家伙在搗鬼。進(jìn)程ID是644,這個(gè)后面我們有用。

(2).分析發(fā)燙的應(yīng)用進(jìn)程在干嘛

需要用到linux下的strace命令,但是android是沒有集成這個(gè)命令的,android版本的下載地址:

http://benno.id.au/android/strace

下載完成后,上傳到手機(jī)中:

我們adb push strace /system/bin,在模擬器上是上傳到/system/bin會(huì)報(bào)out of memory錯(cuò)誤,我們也可以上傳到/data目錄下,如果沒有執(zhí)行權(quán)限,還需要chmod 777 strace.

strace命令有很多參數(shù),直接執(zhí)行strace會(huì)顯示使用說明:

Android App調(diào)試的命令有哪些

其中-p參數(shù)輸入的就是進(jìn)程號(hào),***步中我們找到com.tianxia.test的進(jìn)程ID是644,我們看看這個(gè)應(yīng)用占用這么高的cpu在干嘛?

?

1strace -p 644

輸出如下:

Android App調(diào)試的命令有哪些

它的系統(tǒng)調(diào)用一直是gettimeofday,一直輸出這個(gè),顯然哪里一定進(jìn)入死循環(huán)了,而是是獲取時(shí)間的死循環(huán),然后結(jié)合logcat和代碼,定位這段代碼(就是前面我們給出的那段代碼了)解決這個(gè)bug。

7.采集手機(jī)的cpu運(yùn)行情況.

有時(shí)使用日志我們很難針對(duì)性的獲取我們想要的信息,我們可能需要寫一些最簡(jiǎn)單的腳步放在手機(jī)里面執(zhí)行。

如監(jiān)控cpu占用的記錄cpu_log.sh:

11# !/system/bin/sh

#這個(gè)腳步比較粗糙,是這么個(gè)意思

file=/sdcard/cpu/cpu_info.log

rm $file

until [ 1 -gt 10000 ]

do

echo -e "\n\n\n\n\n---------------">>$file

date >> $file

top -m 5 -n 1 >> $file

sleep 3

done

每隔3s中就會(huì)把手機(jī)的cpu的信息寫到sdcard的cpu目錄下的cpu_info.log文件中,方便我們后續(xù)分析。

ps:使用方法是 push到data目錄下,賦予可執(zhí)行權(quán)限,在shell下執(zhí)行即可。

8.采集某個(gè)應(yīng)用的內(nèi)存數(shù)據(jù)

這個(gè)實(shí)踐和上面的腳本類似,只是命令不一樣我另外單獨(dú)列出來,因?yàn)檫@個(gè)有時(shí)候很有用。

比如,我們要采集com.tianxia.test的內(nèi)存使用情況,分析它是不是會(huì)內(nèi)存泄露,腳步類似:

11# !/system/bin/sh

#這個(gè)腳步比較粗糙,是這么個(gè)意思

file=/sdcard/cpu/mem_info.log

rm $file

until [ 1 -gt 10000 ]

do

echo -e "\n\n\n\n\n---------------">>$file

date >> $file

dumpsys meminfo com.tianxia.test >> $file

sleep 3

done

使用方法也是一樣。

到此,相信大家對(duì)“Android App調(diào)試的命令有哪些”有了更深的了解,不妨來實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!


當(dāng)前名稱:AndroidApp調(diào)試的命令有哪些
轉(zhuǎn)載源于:http://weahome.cn/article/gssocs.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部