android使用traceView進行性能測試

jopen 8年前發布 | 6K 次閱讀 Android開發 移動開發

在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

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!