簡體   English   中英

傑克和Android - Lambda運行時失敗直到干凈的構建

[英]Jack and Android - Lambda runtime failure until clean build

看似隨機,Android Studio安裝的apk已損壞。 它通常以lambdas為中心(但每次都是不同的)。 我正在使用Jack編譯和所有內容的最新版本(最后列出)。 問題一直存在,直到我做了一個干凈的構建(然后一切都很好)。 間歇性故障是一種新現象。 Jack和Java 8功能暫時保持穩定。 不幸的是,我無法確定在片狀失敗開始之前發生了什么變化。

示例代碼:

private static final Ordering<Foo> ORDER_BY_FOO =
    Ordering.natural().onResultOf(Foo::getId);

實際問題分配(在Guava代碼中):

ByFunctionOrdering(Function<F, ? extends T> function, Ordering<T> ordering) {
  this.function = checkNotNull(function);  // <-- Fails
[...]
class ByFunctionOrdering<F, T> extends Ordering<F> {
  final Function<F, ? extends T> function;

示例運行時異常:

E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.mypackage, PID: 32222
java.lang.ExceptionInInitializerError
    at com.mypackage.MyFragment.myOtherMethod(MyFragment.java)
    at com.mypackage.MainActivity.myMethod(MainActivity.java:144)
    at com.mypackage.MainActivity.onActivityResult(MainActivity.java:107)
    at android.app.Activity.dispatchActivityResult(Activity.java:6932)
    at android.app.ActivityThread.deliverResults(ActivityThread.java:4085)
    at android.app.ActivityThread.handleSendResult(ActivityThread.java:4132)
    at android.app.ActivityThread.-wrap20(ActivityThread.java)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1533)
    at android.os.Handler.dispatchMessage(Handler.java:102)
    at android.os.Looper.loop(Looper.java:154)
    at android.app.ActivityThread.main(ActivityThread.java:6119)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:886)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:776)
 Caused by: java.lang.ClassCastException: com.mypackage.-$Lambda$0 cannot be cast to com.google.common.base.Function
    at com.google.common.collect.ByFunctionOrdering.<init>(ByFunctionOrdering.java:39)
    at com.google.common.collect.Ordering.onResultOf(Ordering.java:416)
    at com.mypackage.MyFragment.<clinit>(MyFragment.java:110)
    at com.mypackage.MyFragment.myOtherMethod(MyFragment.java)
    at com.mypackage.MainActivity.myMethod(MainActivity.java:144)
    at com.mypackage.GamesApiManager.onActivityResult(GamesApiManager.java:205)
    at com.mypackage.MainActivity.onActivityResult(MainActivity.java:107)
    at android.app.Activity.dispatchActivityResult(Activity.java:6932)
    at android.app.ActivityThread.deliverResults(ActivityThread.java:4085)
    at android.app.ActivityThread.handleSendResult(ActivityThread.java:4132)
    at android.app.ActivityThread.-wrap20(ActivityThread.java)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1533)
    at android.os.Handler.dispatchMessage(Handler.java:102)
    at android.os.Looper.loop(Looper.java:154)
    at android.app.ActivityThread.main(ActivityThread.java:6119)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:886)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:776)
  • Android Studio / gradle構建工具2.2.2
  • Gradle 2.14.1
  • buildToolsVersion 25.0.0
  • sourceCompatibility / targetCompatibility JavaVersion.VERSION_1_8
  • compileSdkVersion / targetSdkVersion 24

我認為這是Build Tools 25.0.0和25.0.1中的一個錯誤。 回到24.0.3為我解決了這個問題。

更新更新到com.android.tools.build:gradle:2.2.3 ,我有一個完整的工作日,沒有Build Tools v25.0.1的構建錯誤。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM