为Android项目创建自己的jar库时出错

目前我正在研究如何在Android Studio中创建jar库的基础知识。

我按照如何从Android Studio项目 中创建一个.jar以及如何从android studio教程创建一个jar文件 。 并完成了第一个教程中描述的每个步骤。

但是,当我构建并运行此库项目时,它向我显示以下错误

错误:任务’:app:preDexDebug’的执行失败。 com.android.ide.common.process.ProcessException:org.gradle.process.internal.ExecException:进程’命令’C:\ Program Files \ Java \ jdk1.8.0_60 \ bin \ java.exe”以非完成零退出值1

我在SO中研究了这个问题,但这些问题根本没有帮助我。 这对我来说不是内存问题,因为所有其他应用程序都运行得很好。 虽然我的项目没有完美编译,但我从我的库文件夹中获取了库jar文件,当我在其他项目中导入该jar作为库时,我得到了相同的错误消息。

所以我想我在这里错过了一些关键点。 如果有人遇到类似的问题或者可以帮助我,请给我一些建议。

如果您希望我发布任何代码,请告诉我,我会这样做,谢谢。

我只是添加一个java库模块并在那里添加一个非常简单的Multiplication类(检查下面的代码)。 然后在我的项目中将该库模块添加为库。 图书馆代码

 public class Multiplication { public double multiply(int num1, int num2){ return num1*num2; } } 

活动代码

 @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); edt1 = (EditText)findViewById(R.id.et1); edt2 = (EditText)findViewById(R.id.et2); btn = (Button)findViewById(R.id.btn); tv = (TextView)findViewById(R.id.tvRes); multiplication = new Multiplication(); btn.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { double res = multiplication.multiply(Integer.parseInt(edt1.getText().toString()),Integer.parseInt(edt2.getText().toString())); tv.setText(Double.toString(res)); } }); 

的build.gradle

 apply plugin: 'com.android.application' android { compileSdkVersion 22 buildToolsVersion "22.0.1" defaultConfig { applicationId "com.example.myapplication" minSdkVersion 11 targetSdkVersion 22 versionCode 1 versionName "1.0" } buildTypes { release { minifyEnabled false proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' } } } dependencies { compile fileTree(include: ['*.jar'], dir: 'libs') compile 'com.android.support:appcompat-v7:22.2.1' compile files('D:/Work_New/MyApplication/libs/mylibjar.jar') } 

完整的错误日志

 Information:Gradle tasks [:app:assembleDebug] :app:preBuild UP-TO-DATE :app:preDebugBuild UP-TO-DATE :app:compileDebugNdk UP-TO-DATE :app:checkDebugManifest :app:preReleaseBuild UP-TO-DATE :mylibjar:compileJava UP-TO-DATE :mylibjar:processResources UP-TO-DATE :mylibjar:classes UP-TO-DATE :mylibjar:jar UP-TO-DATE :app:prepareComAndroidSupportAppcompatV72221Library UP-TO-DATE :app:prepareComAndroidSupportSupportV42221Library UP-TO-DATE :app:prepareDebugDependencies :app:compileDebugAidl UP-TO-DATE :app:compileDebugRenderscript UP-TO-DATE :app:generateDebugBuildConfig UP-TO-DATE :app:generateDebugAssets UP-TO-DATE :app:mergeDebugAssets UP-TO-DATE :app:generateDebugResValues UP-TO-DATE :app:generateDebugResources UP-TO-DATE :app:mergeDebugResources UP-TO-DATE :app:processDebugManifest UP-TO-DATE :app:processDebugResources UP-TO-DATE :app:generateDebugSources UP-TO-DATE :app:compileDebugJava UP-TO-DATE :app:preDexDebug UNEXPECTED TOP-LEVEL EXCEPTION: com.android.dx.cf.iface.ParseException: bad class file magic (cafebabe) or version (0034.0000) at com.android.dx.cf.direct.DirectClassFile.parse0(DirectClassFile.java:472) at com.android.dx.cf.direct.DirectClassFile.parse(DirectClassFile.java:406) at com.android.dx.cf.direct.DirectClassFile.parseToInterfacesIfNecessary(DirectClassFile.java:388) at com.android.dx.cf.direct.DirectClassFile.getMagic(DirectClassFile.java:251) at com.android.dx.command.dexer.Main.processClass(Main.java:704) at com.android.dx.command.dexer.Main.processFileBytes(Main.java:673) at com.android.dx.command.dexer.Main.access$300(Main.java:83) at com.android.dx.command.dexer.Main$1.processFileBytes(Main.java:602) at com.android.dx.cf.direct.ClassPathOpener.processArchive(ClassPathOpener.java:284) at com.android.dx.cf.direct.ClassPathOpener.processOne(ClassPathOpener.java:166) at com.android.dx.cf.direct.ClassPathOpener.process(ClassPathOpener.java:144) at com.android.dx.command.dexer.Main.processOne(Main.java:632) at com.android.dx.command.dexer.Main.processAllFiles(Main.java:510) at com.android.dx.command.dexer.Main.runMonoDex(Main.java:280) at com.android.dx.command.dexer.Main.run(Main.java:246) at com.android.dx.command.dexer.Main.main(Main.java:215) at com.android.dx.command.Main.main(Main.java:106) ...while parsing com/MultiplicationTest/Multiplication.class 1 error; aborting Error:Execution failed for task ':app:preDexDebug'. > com.android.ide.common.process.ProcessException: org.gradle.process.internal.ExecException: Process 'command 'C:\Program Files\Java\jdk1.8.0_60\bin\java.exe'' finished with non-zero exit value 1 

虽然我在编译项目时没有显示任何错误,但它向​​我显示了我提到的上述错误。

更新2

根据日志,您使用Java 1.8构建* .jar。 Android支持的最大java版本是1.7。 因此,您必须将源代码兼容性设置为1.7并重建jar文件。

如果您不是从gradle(或Android Studio)构建此jar,则需要更改JDK版本(文件 – >项目结构 – > SDK位置 – > JDK位置)。

对于gradle模块,请参阅“Update 1”


更新1

对于你来说,java模块(你试图从中获取jar)放下这些行:

 apply plugin: 'java' sourceCompatibility = 1.7 targetCompatibility = 1.7 

尝试将下一个代码放入Android模块的gradle文件中:

 android { compileOptions { sourceCompatibility JavaVersion.VERSION_1_7 targetCompatibility JavaVersion.VERSION_1_7 } } 

"non-zero exit value 1"错误的原因可能不同。

1.删​​除库,然后重建项目以检查它是否正常工作。

2.如果工作正常,请从dependencies项中删除compile filetree选项并重新生成它

 dependencies { compile 'com.android.support:appcompat-v7:22.2.1' compile files('D:/Work_New/MyApplication/libs/mylibjar.jar') } 
  1. 如果仍然存在此问题,请创建一个简单项目并首先将jar库导入此项目。 接下来逐个添加这些其他依赖项以找出问题。如果问题没有再次发生,请将所有java文件复制到此新项目。 接下来一个接一个地复制"image"文件。 通常可绘制的图像文件导致此问题"non-zero exit value 1"

编辑:还在你的依赖的android{内部添加这个:

 dexOptions { preDexLibraries = true } 

在android中你不能使用.jar文件作为其他android项目的库。 你必须将android-project导入为库并将项目设置为lib-project。 你必须将android-lib-project导入到你正在使用它的每个其他android项目中。

这就是eclipse中的情况,我想在Android Studio中它是一种类似的方法

我假设你的工作区目前有两个项目:1)Android应用程序项目(在gradle文件中标记为“apply plugin:’com.android.application’”)2)java库项目(“apply plugin:’java’”)它们都通过settings.gradle文件链接。

您应该能够通过’assemble’构建java项目,然后在build / libs文件夹中输出.jar文件(这也可以通过Gradle的’jar’命令完成)。

也许您可以在Android Studio中发布树结构的屏幕截图以获得更多帮助。

尝试导入你的模块(一个java库),如下所示:

 compile project(':MyLib'); // MyLib is a name of your module 

在使用Java 1.8 SDK构建我的android解决方案(有几个java模块)时,我也遇到了同样的错误。 最后我用Gradle Retrolamdba插件修复了它

将以下类路径添加到根项目中的build.gradle文件中

 classpath 'me.tatarka:gradle-retrolambda:3.2.4' 

并且retrolamdba插件位于子项目/ java模块(jar库)中的build.gradle

 apply plugin: 'java' apply plugin: 'me.tatarka.retrolambda'