android使用traceView進行性能測試
在android開發中,經常會需要優化apk的性能,然而那些方法是比較耗費性能的,哪些方法又是比較占用內存的,我們很難得知,好在google為我們提供了一個工具,traceView,該工具在sdk的tools文件夾里邊,只要配置了環境變量,就可以直接使用的。
traceView是Android中為開發者提供的一個可視化的工具,用來評測app中每一個方法運行的性能。
我首先編寫一個簡單的activity,如下:
package com.example.testtrace; import android.app.Activity; import android.os.Bundle; import android.os.Debug; import android.view.Menu; public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Debug.startMethodTracing("haha"); calcuteAdd(); calcutePlus(); } public void calcuteAdd() { int sum = 0; for (int i = 0; i < 10000; i++) { sum += i; } } public void calcutePlus() { int total = 100000; for (int i = 0; i < 3000; i++) { total -= i; } } @Override protected void onStop() { // TODO Auto-generated method stub super.onStop(); Debug.stopMethodTracing(); } @Override public boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.main, menu); return true; } }
代碼很簡單,就是分別運行了加法和減法這兩個方法。細心的碼農可能已經發現,我在onCreate方法中運行了一個方法
Debug.startMethodTracing("haha");
在onStop方法中運行了一個方法:
Debug.stopMethodTracing();
沒錯,就是在onCreate方法當中開啟數據的采集,在onStop方法當中停止數據的采集。其中”haha”是采集到的數據保存的文件名稱.
將應用安裝到sdcard上,然后再sdcard上會生成一個haha.trace文件,然后將該haha.trace文件導出,通過sdk中的tools目錄下的traceview來進行分析.
我們首先將保存在sdcard根目錄的”haha.trace”拷貝到本地,然后執行”traceview d:/haha.trace”,注意必須要首先配置traceview的環境變量。此時會看到下面這樣一個面板:
左邊就是我們運行的方法:每一個方法都有一個parent和children,其中:
parent:表示那個方法調用了這個方法
children:表示該方法調用了那些方法
在所有的方法右邊有很多的選項卡,下面逐個解釋其代表的含義:
1.Incl Cpu Time%
該方法運行期間所執行的時間與總時間的百分比
2.Incl Cpu Time
該方法本身運行需要的時間
3.Excl Cpu Time%
不包括子方法,也就是自己本身運行的時間占總時間的百分比
4.Excl Cpu Time
不計入該方法中調用其他方法的時間,所以看那個方法消耗性能,主要是看這個參數的值
5.Incl Real Time%
改方法本身運行的真實時間占總時間的百分比
6.Incl Real Time
該方法本身運行的時間
7.Excl Real Time%
該方法本身占用cpu的時間和該方法本身運行的時間和總時間的百分比
8.calls+recurcalls/total
該方法運行期間被調用的總次數
9.cpu time/call
運行期間,該方法運行所需要的時間
可以啊看到我們在activity中寫的一個calcuteAddF方法的各個方面的指數:
ok,關于traceview的學習就到這里了,希望大家能夠喜歡。
來自: http://blog.csdn.net//mockingbirds/article/details/46418845