日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
Android學(xué)習(xí)系列(29)--App調(diào)試的幾個命令實踐

1.logcat命令

創(chuàng)新互聯(lián)公司專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都網(wǎng)站建設(shè)、網(wǎng)站制作、城東網(wǎng)絡(luò)推廣、小程序開發(fā)、城東網(wǎng)絡(luò)營銷、城東企業(yè)策劃、城東品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們最大的嘉獎;創(chuàng)新互聯(lián)公司為所有大學(xué)生創(chuàng)業(yè)者提供城東建站搭建服務(wù),24小時服務(wù)熱線:13518219792,官方網(wǎng)址:www.cdcxhl.com

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

?

1adb logcat -v time

2.bugreport命令

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

?

1adb bugreport > xxx.log

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

3.dumpsys命令

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

?

1

2

3

4

5

6

7dumpsys [options]

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

cpuinfo 顯示CPU信息

account 顯示accounts信息

activity 顯示所有的activities的信息

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

wifi 顯示wifi信息

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

?

1

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

adb shell dumpsys meminfo com.tianxia.test

效果圖如下:

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

4.top命令

這個查看cpu信息太方便了。

?

1top -m 5 -t

我們看看效果圖,其中按cpu大小列出5個進程列表。

com.tianxia.test的cpu過高,會導(dǎo)致手機發(fā)燙。同時利用這個信息,可以監(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中,如果沒有這個文件自行創(chuàng)建。然后重啟手機,就能看到每個應(yīng)用詳細的查詢數(shù)據(jù)庫的sql語句信息,對于調(diào)試數(shù)據(jù)庫,分析和優(yōu)化數(shù)據(jù)庫sql異常非常有用。

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

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

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

?

1

2

3

4

5

6

7

8@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.main);

while(true) {

System.currentTimeMillis();

}

}

這個應(yīng)用打開后會一直獲取系統(tǒng)時間,因為在主線程,肯定導(dǎo)致應(yīng)用ANR,也會一直浪費系統(tǒng)cpu,手機發(fā)熱,我們運行它。

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

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

使用top命令:

?

1top -m 5 -t

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

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

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

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

下載完成后,上傳到手機中:

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

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

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

?

1strace -p 644

輸出如下:

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

7.采集手機的cpu運行情況.

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

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

?

1

2

3

4

5

6

7

8

9

10

11# !/system/bin/sh

#這個腳步比較粗糙,是這么個意思

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中就會把手機的cpu的信息寫到sdcard的cpu目錄下的cpu_info.log文件中,方便我們后續(xù)分析。

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

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

這個實踐和上面的腳本類似,只是命令不一樣我另外單獨列出來,因為這個有時候很有用。

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

?

1

2

3

4

5

6

7

8

9

10

11# !/system/bin/sh

#這個腳步比較粗糙,是這么個意思

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

使用方法也是一樣。

9.小結(jié)

零零碎碎的一直沒有時間整理,有常用的也有不常用的,算是一些小技巧,感覺網(wǎng)上這方面的分享比較少,有時和朋友們談起這些調(diào)試方法,特別是龍哥,硬是要求我今天寫出來與大家分享,只好獻丑,說不定對于解決一些疑難雜癥有奇效,呵呵,想到什么寫什么吧,想到幾個寫幾個,也是一個學(xué)習(xí)的記錄。

【編輯推薦】

  1. Android 的中長期焦慮?
  2. 產(chǎn)品交互設(shè)計:iPhone和Android的控件對比
  3. 為什么iOS應(yīng)用比Android應(yīng)用更好看

網(wǎng)站欄目:Android學(xué)習(xí)系列(29)--App調(diào)試的幾個命令實踐
網(wǎng)頁鏈接:http://m.5511xx.com/article/dpsdddp.html