1

我正在使用一些本机 java 8 功能(例如 lambda)测试 Android Studio 3.0 预览版

我有两个模块(app、mylibrary)

在我的应用程序build.gradle文件中,我包含了库模块。

implementation project(':mylibrary')

在 mylibrarybuild.gradle文件中,我指定了 java 版本以测试 lambda 表达式。

compileOptions {
    android.compileOptions.sourceCompatibility 1.8
    android.compileOptions.targetCompatibility 1.8
}

在我将 android studio 从 canary 3 升级到 canary 5 之前,它对我来说工作得很好,我的方法被打破了。

我收到以下动态错误消息

Information:Gradle tasks [:app:assembleDebug]
/Users/chchi/Documents/PayPal/Android/AS3.0Preview/app/src/main/java/com/example/chchi/myapplication/MainActivity.kt
Error:Error converting bytecode to dex:
Cause: invalid opcode ba (invokedynamic requires --min-sdk-version >= 26)
Error:com.android.dx.cf.code.SimException: invalid opcode ba (invokedynamic requires --min-sdk-version >= 26)
...
...
Error:  ... 5 more
Error:...at bytecode offset 00000016
Error:locals[0000]: Lcom/android/tools/fd/runtime/IncrementalChange;
Error:locals[0001]: <invalid>
Error:...while working on block 0016
Error:...while working on method testJava8feature:()V
Error:...while processing testJava8feature ()V
Error:...while processing com/example/mylibrary/LamdaTest.class
Error:Execution failed for task ':app:transformClassesWithDexBuilderForDebug'.
> com.android.build.api.transform.TransformException: com.android.builder.dexing.DexArchiveBuilderException: com.android.builder.dexing.DexArchiveBuilderException: Unable to convert input to dex archive.
Information:BUILD FAILED in 8s
Information:40 errors
Information:1 warning
Information:See complete output in console

在我按照说明minSdkVersion撞到26. 我收到有关转换为 dex 文件的以下错误。

Information:Gradle tasks [:app:assembleDebug]
Error:Error converting bytecode to dex:
Cause: Shouldn't happen
Error:com.android.dex.util.ExceptionWithContext: Shouldn't happen
Error:  at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
Error:  at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
Error:  at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
Error:  at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
...
Error:Caused by: com.android.dex.util.ExceptionWithContext: Shouldn't happen
Error:  at com.android.dex.util.ExceptionWithContext.withContext(ExceptionWithContext.java:45)
Error:  at com.android.dx.dex.file.MixedItemSection.placeItems(MixedItemSection.java:320)
Error:  at com.android.dx.dex.file.DexFile.toDex0(DexFile.java:611)
Error:  at com.android.dx.dex.file.DexFile.toDex(DexFile.java:242)
Error:  at com.android.builder.dexing.DxDexArchiveBuilder.lambda$processJobChunk$0(DxDexArchiveBuilder.java:118)
Error:  ... 5 more
Error:Caused by: java.lang.RuntimeException: Shouldn't happen
Error:  at com.android.dx.dex.file.ValueEncoder.constantToValueType(ValueEncoder.java:276)
Error:  at com.android.dx.dex.file.ValueEncoder.writeConstant(ValueEncoder.java:137)
Error:  at com.android.dx.dex.file.ValueEncoder.writeArray(ValueEncoder.java:310)
Error:  at com.android.dx.dex.file.CallSiteItem.place0(CallSiteItem.java:63)
Error:  at com.android.dx.dex.file.OffsettedItem.place(OffsettedItem.java:242)
Error:  at com.android.dx.dex.file.MixedItemSection.placeItems(MixedItemSection.java:311)
Error:  ... 8 more
Error:...while placing call site{method-handle{invoke-static,method{java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;}}, string{"adder"}, proto{()Lcom/example/mylibrary/PayPalInterface;}, (II)V, method-handle{invoke-static,method{com.example.mylibrary.LamdaTest.lambda$testJava8feature$0:(II)V}}, (II)V}
Error:...while writing section 12
Error:Execution failed for task ':app:transformClassesWithDexBuilderForDebug'.
> com.android.build.api.transform.TransformException: com.android.builder.dexing.DexArchiveBuilderException: com.android.builder.dexing.DexArchiveBuilderException: Unable to convert input to dex archive.
Information:BUILD FAILED in 1s
Information:38 errors
Information:0 warnings
Information:See complete output in console

最终,为了让编译器通过,我不得不将我的所有模块都撞到1.8(无需设置minSdkVersion为)。26有没有办法让我的库模块1.8只使用并且任何使用我的库的人仍然可以留在他们现在的位置(1.7)?

如果我只使用具有高向后兼容性的某些功能,那么我为什么要担心是否有人使用我的库目标1.8呢?

4

1 回答 1

1

这是新的 Android Gradle 插件的错误 - 我的库项目面临同样的问题。似乎desugar- 将 Java 8 字节码转换为旧版字节码 - 不适用于库项目。

我已经向谷歌报告了问题。希望它修复。 https://issuetracker.google.com/issues/63513242

于 2017-07-10T05:49:39.477 回答