1

アプリケーションの起動時間に問題があります。アプリを起動すると (メイン アクティビティを起動)、アプリが最終的に表示されるまでに約 3 ~ 4 秒かかりました。onCreate メソッドからすべてを削除したため、単純な LinearLayout を設定する setContentView(R.layout.activity_main) のみが含まれています。MainActivity には、複雑なレイアウト構造やその他の重いコードはありません。

起動時間を記録するために、次の出力が得られる両方の adb shell コマンドを使用しました。

12-06 11:40:06.395 918 939 I am_activity_launch_time: [0,78089240, de.package.package/.MainActivity,3724,3724]

また、TraceView:

ここに画像の説明を入力

私は TraceView にあまり詳しくないので、出力の多くは理解できませんが、「bindApplication」の部分には長い時間がかかります。また、アプリケーションに必要な gradle ファイルにいくつかのライブラリをインポートしました。これらは起動時間に影響する可能性があります。

apply plugin: 'com.android.application'

android {
    compileSdkVersion 25
    buildToolsVersion "25.0.0"

    repositories {
        mavenCentral()
        jcenter()
    }

    defaultConfig {
        applicationId "de.watado.watado"
        minSdkVersion 16
        targetSdkVersion 25
        versionCode 1
        versionName "1.0"
    }
    buildTypes {
        release {
            minifyEnabled true
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}
dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    compile 'com.android.support:appcompat-v7:25.0.1'
    compile 'com.android.support:support-v4:25.0.1'
    compile 'com.squareup.retrofit2:retrofit:2.1.0'
    compile 'com.github.bumptech.glide:glide:3.7.0'
    compile 'com.balysv:material-ripple:1.0.2'
    compile 'com.google.android.gms:play-services-location:9.8.0'
    compile 'com.google.android.gms:play-services-maps:9.8.0'
    compile 'com.google.maps.android:android-maps-utils:0.4.4'
    compile 'com.crystal:crystalrangeseekbar:1.1.1'
    compile 'com.android.support:cardview-v7:25.0.1'
}

私のアプリケーションが表示されるまでに時間がかかる理由を知っている人はいますか?

編集: MainActivity

public class MainActivity extends FragmentActivity implements View.OnClickListener,
                                                          ViewPager.OnPageChangeListener{

private TextView tvHome, tvCat, tvSearch, tvLike;
private int currentPos = 0;
private ViewPager pager;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
}

@Override
public void onClick(View view) {
    switch (view.getId()){
        case R.id.textView_home:
            changeButtonState(-1);
            break;
        case R.id.textView_categories:
            changeButtonState(0);
            break;
        case R.id.textView_search:
            changeButtonState(1);
            break;
        case R.id.textView_like:
            changeButtonState(2);
            break;
    }
}
}
4

2 に答える 2