2016-11-04 3 views
16

Android Studioがインストールするapkが壊れているようです。それは通常ラムダを中心にしています(ただし毎回違っています)。私はジャックのコンパイルとすべての最新バージョンを使用しています(最後にリストされています)。問題は、私がクリーンなビルドを行うまで(そして全てがうまくいくまで)続く。断続的な失敗は新しい現象です。ジャックとJava 8の機能はしばらくの間安定していました。残念ながら、不安定な失敗が始まる前に何が変わったのかを特定することはできません。ジャックとアンドロイド - クリーンビルドまでのラムダランタイムエラー

例コード:

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

実際の問題の割り当て(グアバコードで):

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メーカー/ Gradleのビルドツール2.2 .2
  • のGradle 2.14.1
  • buildToolsVersion 25.0.0
  • sourceCompatibility/targetCompatibility JavaVersion.VERSION_1_8
  • compileSdkVersion/targetSdkVersion 24
+0

24.0.3に戻る以外の回避策はありますか? 25.0.1も私のためにそれを修正していないようです。 –

+0

Android Studioを使用していない数週間後、私は最新のアップデートバッチをインストールし、過去2日間は何の問題も見たことがありません。それは更新が何かを修正したということを意味するわけではありません...しかしそれは有望です。私は再び失敗を見たら私は戻って報告する – colithium

+0

そしてそれは復讐と戻っているようだ。他のすべての変更は、きれいにビルドする必要があります。 – colithium

答えて

3

私は、これはビルドツール25.0.0および25.0のバグであると仮定します。 1。 24.0.3に戻すと、この問題が解決されました。

更新 com.android.tools.build:gradle:2.2.3に更新した後、私はBuild Tools v25.0.1でビルドエラーのない完全な勤務時間を過ごしました。

関連する問題