java - 应用程序启动时间过长

标签 java android android-studio gradle android-traceview

我的应用程序启动时间有问题。如果我启动我的应用程序(启动主要 Activity ),大约需要 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:

enter image description here

我对 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'
}

有谁知道为什么我的申请需要这么长时间才能显示?

编辑: 主要 Activity

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;
    }
}
}

最佳答案

您可以发布您的自定义应用程序类和第一个 Activity 吗?另外,请检查 Release模式下的运行时间 - Debug模式可能需要更长的时间,因为例如即时运行

关于java - 应用程序启动时间过长,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40994136/

相关文章:

java - Pascal 三角程序中的 ArrayIndexOutOfBounds 问题

java - 从 Java 应用程序向/从 SocketIO/nodejs 服务器订阅/发布消息?

android - 带锁文件的 Mercurial 替代方案

android - 如何为字符串资源中的文本设置额外的粗体?

android - 我们可以在一个 xml 文件中创建多个形状并将它们指向这个单个文件吗?

java - 什么是NullPointerException,我该如何解决?

java - Android 手机上的文本文件

android - 如何获取 Google DeskClock 应用程序中设置的闹钟时间?

java - ProgressDialog 打破了我的脖子并消除了方法问题

java - 如何存储用户输入以供继续使用?