我遇到了应用程序启动时的问题。如果我启动我的应用程序(启动主要活动),则需要大约3-4秒才能最终显示应用程序。我从onCreate方法中删除了所有内容,因此它只包含setContentView(R.layout.activity_main),它设置了一个简单的LinearLayout。 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;
}
}
}
答案 0 :(得分:0)
您可以发布自定义Application类和第一个活动吗?另外,请在发布模式下检查运行时间 - 调试模式可能需要更长时间,因为例如InstantRun
答案 1 :(得分:0)
可能的原因:
使用Multidex
会增加启动时间。
如果清除数据并启动应用程序,则需要更长时间,因为 ART运行时将首先编译应用程序。