Android studio Jack和Android-Lambda运行时失败,直到清理构建

Android studio Jack和Android-Lambda运行时失败,直到清理构建,android-studio,lambda,android-jack-and-jill,Android Studio,Lambda,Android Jack And Jill,Android Studio安装的apk似乎是随机损坏的。它通常以lambdas为中心(但每次都不同)。我正在使用Jack编译和所有内容的最新版本(在末尾列出)。问题一直存在,直到我完成了一个干净的构建(然后一切都很好)。间歇性故障是一种新现象。Jack和Java8的特性在一段时间内保持稳定。不幸的是,我无法准确地指出在这些失败开始之前发生了什么变化 示例代码: private static final Ordering<Foo> ORDER_BY_FOO = Orderin

Android Studio安装的apk似乎是随机损坏的。它通常以lambdas为中心(但每次都不同)。我正在使用Jack编译和所有内容的最新版本(在末尾列出)。问题一直存在,直到我完成了一个干净的构建(然后一切都很好)。间歇性故障是一种新现象。Jack和Java8的特性在一段时间内保持稳定。不幸的是,我无法准确地指出在这些失败开始之前发生了什么变化

示例代码:

private static final Ordering<Foo> ORDER_BY_FOO =
    Ordering.natural().onResultOf(Foo::getId);
private静态最终订购单=
Ordering.natural().onResultOf(Foo::getId);
实际问题分配(番石榴代码):

ByFunctionOrdering(函数函数,排序){

this.function=checkNotNull(function);//我假设这是构建工具25.0.0和25.0.1中的一个bug。恢复到24.0.3修复了这个问题

更新
更新到
com.android.tools.build:gradle:2.2.3
后,我用构建工具v25.0.1度过了一个完整的工作日,没有出现构建错误。

除了返回到24.0.3之外,你有没有找到其他解决方法?25.0.1似乎对我来说也无法修复它。在与android Studio停止工作两周后,我安装了最新的一批更新和更新在过去的两天里没有看到任何问题。这并不意味着更新修复了任何问题…但它是有希望的。如果我再次看到故障,我会报告回来,它似乎是报复性的。几乎所有其他的更改都需要一个干净的构建。你能修复这个问题吗?声称它已修复,但他们也宣布他们正在删除j确认/吉尔。我已经在2.2.3了。还有其他选择吗?我发布了详细信息。我的答案是1.5年前写的。现在你应该有更多最新版本的东西了。
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)