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:删除<uses-sdk ... />
行。这是多余的,因为 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”