Android Studio:意外的***异常:

Posted

技术标签:

【中文标题】Android Studio:意外的***异常:【英文标题】:Android Studio : UNEXPECTED TOP-LEVEL EXCEPTION: 【发布时间】:2015-08-29 10:41:28 【问题描述】:

我该如何解决这个错误

错误:任务 ':app:dexDebug' 执行失败。 com.android.ide.common.process.ProcessException: org.gradle.process.internal.ExecException: Process 'command'/Library/Java/JavaVirtualMachines/jdk1.7.0_67.jdk/Contents/Home/bin/java'' 完成非零退出值 2

App Build.gradle

apply plugin: 'com.android.application'

android 
compileSdkVersion 22
buildToolsVersion "22.0.1"


packagingOptions 
    exclude 'META-INF/DEPENDENCIES'
    exclude 'META-INF/ASL2.0'
    exclude 'META-INF/NOTICE'
    exclude 'META-INF/NOTICE.txt'
    exclude 'META-INF/LICENSE'
    exclude 'META-INF/LICENSE.txt'
    exclude 'META-INF/license.txt'
    exclude 'META-INF/notice.txt'


defaultConfig 
    applicationId "com.app"
    minSdkVersion 10
    targetSdkVersion 22
    versionCode 1
    versionName "1.0"


buildTypes 
    release 
        minifyEnabled false
        proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
    



dependencies 

compile 'com.android.support:appcompat-v7:22.1.1' // Do NOT use 22.2.0 even it is newer one. It reported to cause some problems with other dependencies.
compile fileTree(dir: 'libs', include: '*.jar')
compile('com.google.android.gms:play-services:7.5.+')
        
            exclude module: 'support-v4'
        
compile group:'com.octo.android.robospice', name:'robospice-spring-android', version:'1.4.7'

compile 'com.octo.android.robospice:robospice-spring-android:1.4.7'

compile group:'org.codehaus.jackson', name:'jackson-mapper-asl', version:'1.9.11'

compile 'com.fasterxml.jackson.core:jackson-databind:2.2.2'

compile 'com.fasterxml.jackson.core:jackson-annotations:2.2.2'

compile 'com.fasterxml.jackson.core:jackson-core:2.2.2'

compile 'com.google.code.gson:gson:2.2.4'

compile 'com.octo.android.robospice:robospice-ormlite:1.4.6'

compile('org.simpleframework:simple-xml:2.7.1') 
//        exclude module: 'xpp3'
//        exclude group: 'stax'
    exclude group: 'xpp3', module: 'xpp3'
    exclude group: 'stax', module: 'stax'
    exclude group: 'stax', module: 'stax-api'



项目分级

// Top-level build file where you can add configuration options common to all sub-projects/modules.

buildscript 
repositories 
    jcenter()

dependencies 
    classpath 'com.android.tools.build:gradle:1.2.3'

    // NOTE: Do not place your application dependencies here; they belong
    // in the individual module build.gradle files



allprojects 
repositories 
    jcenter()


Android Mainfest

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.app" >

<!-- Permission - Internet Connect -->
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.GET_ACCOUNTS" />
<uses-permission android:name="android.permission.USE_CREDENTIALS" />

<!-- Permission - Location - GPS Service -->
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />

<!-- Network State Permissions -->
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

<!-- Call Phone Permissions -->
<uses-permission android:name="android.permission.CALL_PHONE" />

<application
    android:name=".app.AppHelper"
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/AppTheme">

    <service
        android:name="com.octo.android.robospice.Jackson2SpringAndroidSpiceService"
        android:exported="false" />

    <meta-data
        android:name="com.google.android.gms.version"
        android:value="@integer/google_play_services_version" />

    <meta-data
        android:name="com.google.android.maps.v2.API_KEY"
        android:value="AIzaSyCU__5jhNC-QaU9tXNpr7ikPio3km1UYe8" />

    <activity
        android:name=".ui.splash.SplashActivity"
        android:label="@string/app_name"
        android:noHistory="true"
        android:screenOrientation="portrait"
        android:theme="@style/AppTheme">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>

    <activity
        android:name=".ui.base.BaseDrawerFragmentActivity"
        android:configChanges="locale"
        android:label=""
        android:launchMode="singleTask"
        android:screenOrientation="portrait"
        android:theme="@style/AppTheme">
    </activity>

</application>

Libs 文件夹 现在不存在任何 Libs 文件夹

【问题讨论】:

你以前问过这个问题(而不是重复问题,你应该对原来的问题给予赏金):***.com/questions/29518323/… 也许您应该更新您的构建工具? 21.1.2 旧了,现在有 22.0.1 @ Quintin Balsdon 这是同样的错误,但另一个应用程序的结构不同,所以我将它作为另一个问题发布 【参考方案1】:

您是否尝试过在 build.gradle 中注释掉以下内容:

//compile fileTree(dir: 'libs', include: ['*.jar'])

参考:https://code.google.com/p/android/issues/detail?id=161605

【讨论】:

是的,我之前找到了这个页面并测试了如果我评论了这一行但什么也没发生会发生什么【参考方案2】:

欢迎。您正处于 Android gradle 地狱的第一步。

    将 SDK 管理器中的 Android SDK 组件更新为最新的组件,包括 Extra > Google Repository(建议在 Extra 中添加几乎所有组件)。

    让我们清理您当前的文件。

    AndroidManifest.xml:删除&lt;uses-sdk ... /&gt; 行。这是多余的,因为 gradle 文件已经定义了它。

    Build.gradle:注释所有compile files('libs/xxxxxxx.jar') 行。第一行compile fileTree(dir: 'libs', include: ['*.jar']) 将包含libs 文件夹中的所有jar 文件。并且,使用来自 maven 存储库而不是 jar 文件的compile,以保持您的依赖关系新鲜。

例如,SimpleXML 的存储库 ID 如下。将代码放在compile fileTree(dir: 'libs', include: ['*.jar']) 行下方,并删除 libs 文件夹中的“simple-xml-2.7.1.jar”文件。

compile('org.simpleframework:simple-xml:2.7.1') 
    exclude module: 'stax'
    exclude module: 'stax-api'
    exclude module: 'xpp3'

同样,在您的 libs 文件夹中找到每个 jar 文件的存储库 id,并将其替换为 compile fileTree(dir: 'libs', include: ['*.jar']) 行下方。仅将无法在 maven 存储库中找到的 jar 文件保留在 libs 文件夹中。

最后,删除proguardFiles 行。您需要在一般情况下找到并解决问题,然后再应用progruard。

    将 buildToolsVersion 和 compileSdkVersion 的版本设置为最新版本。

我今天的推荐如下, (将来有人会看到此帖子时,数字可能会有所不同)

android 
    compileSdkVersion 22
    buildToolsVersion '22.0.1'

    dexOptions 
        preDexLibraries = false
        javaMaxHeapSize "2g"
    
    defaultConfig 
        ...
        multiDexEnabled = false
    
    lintOptions 
        abortOnError false
        disable 'InvalidPackage'
    

    ...



dependencies 
    compile 'com.android.support:appcompat-v7:22.1.1' // Do NOT use 22.2.0 even it is newer one. It reported to cause some problems with other dependencies.
    compile fileTree(dir: 'libs', include: '*.jar')
    compile('com.google.android.gms:play-services-gcm:7.5.+')
        
            exclude module: 'support-v4'
        
 

    再次命令gradle assembleDebug。 (对于 Windows,gradlew assembleDebug

    如果再次失败,尝试一一查找并修复依赖版本冲突问题。您可能会在我的代码中看到exclude module: ...。这些解决了冲突问题。详细说明见链接:https://***.com/a/30649660/361100

【讨论】:

Youngjae 检查我更新的 gradle ,删除了所有库,但仍然发生同样的错误。 @ahmedShoeib // 首先删除 proguardFiles 行。而且,您是否进行了我推荐的第 5 项?如果是,我建议您执行gradle assembleDebug --stacktrace 并准确查找问题。您可以发布--stacktrace--info 选项的失败结果。 命令的结果 ./gradlew -q dependencies app:dependencies --configuration compile : 检查这个 url gist.github.com/ahmedshoeib/f433839f392e7a650eaa 在此处查看更新的 gradle 和命令输出gist.github.com/ahmedshoeib/27b0ec30309f787b30f9 @ahmedShoeib // 我建议你使用--debug (不是--info 抱歉上面我的错误评论)或--stacktrace 选项执行gradle。它会显示错误原因。【参考方案3】:

令人惊讶的是,这对我有用

defaultConfig 
multiDexEnabled true

来源: Android Studio fails to debug with error org.gradle.process.internal.ExecException

【讨论】:

【参考方案4】:

当我导入所有 Google Play 服务 API 时,我也遇到了同样的错误,就像你做的那样

compile('com.google.android.gms:play-services:7.5.+')

尝试删除此行并仅导入您需要的服务 API:Google Play Services Setup

【讨论】:

以上是关于Android Studio:意外的***异常:的主要内容,如果未能解决你的问题,请参考以下文章

Android Studio错误尝试获取屏幕截图:“从设备获取屏幕截图时出现意外错误:EOF”

android studio adb 语法错误:“)”意外

Android studio坑之签名异常

Android Studio 在 Mac Catalina 测试版上意外退出

Android Studio 在 Mac 上意外退出

Visual Studio - Android - “模拟器意外退出。请检查模拟器设置”