2016-11-17 26 views
0

的应用工作在调试,但不是在释放的Android EventBus应用程序崩溃在释放模式由于没有@Subcribe方法

Process: com.rubenwardy.monzolytics, PID: 14943 
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.rubenwardy.monzolytics/com.rubenwardy.monzolytics.MainActivity}: org.greenrobot.eventbus.EventBusException: Subscriber class com.rubenwardy.monzolytics.MainActivity and its super classes have no public methods with the @Subscribe annotation 
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2344) 
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2404) 
    at android.app.ActivityThread.access$800(ActivityThread.java:145) 
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1323) 
    at android.os.Handler.dispatchMessage(Handler.java:102) 
    at android.os.Looper.loop(Looper.java:135) 
    at android.app.ActivityThread.main(ActivityThread.java:5319) 
    at java.lang.reflect.Method.invoke(Native Method) 
    at java.lang.reflect.Method.invoke(Method.java:372) 
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1016) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:811) 
Caused by: org.greenrobot.eventbus.EventBusException: Subscriber class com.rubenwardy.monzolytics.MainActivity and its super classes have no public methods with the @Subscribe annotation 
    at org.greenrobot.eventbus.SubscriberMethodFinder.findSubscriberMethods(SubscriberMethodFinder.java:67) 
    at org.greenrobot.eventbus.EventBus.register(EventBus.java:136) 
    at com.rubenwardy.monzolytics.MainActivity.onStart(MainActivity.java:88) 
    at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1220) 
    at android.app.Activity.performStart(Activity.java:5992) 
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2307) 
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2404)  
    at android.app.ActivityThread.access$800(ActivityThread.java:145)  
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1323)  
    at android.os.Handler.dispatchMessage(Handler.java:102)  
    at android.os.Looper.loop(Looper.java:135)  
    at android.app.ActivityThread.main(ActivityThread.java:5319)  
    at java.lang.reflect.Method.invoke(Native Method)  
    at java.lang.reflect.Method.invoke(Method.java:372)  
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1016)  
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:811)  

这是我的gradle这个文件:https://gist.github.com/rubenwardy/b467d1efd79c671f9a932d98768ff656
这里是我的proguard的文件:

-keep class com.androidplot.** { *; } 
# Platform calls Class.forName on types which do not exist on Android to determine platform. 
-dontnote retrofit2.Platform 
# Platform used when running on RoboVM on iOS. Will not be used at runtime. 
-dontnote retrofit2.Platform$IOS$MainThreadExecutor 
# Platform used when running on Java 8 VMs. Will not be used at runtime. 
-dontwarn retrofit2.Platform$Java8 
# Retain generic type information for use by reflection by converters and adapters. 
-keepattributes Signature 
# Retain declared checked exceptions for use by a Proxy instance. 
-keepattributes Exceptions 

-keepattributes *Annotation* 
-keepclassmembers class ** { 
    @org.greenrobot.eventbus.Subscribe <methods>; 
} 
-keep enum org.greenrobot.eventbus.ThreadMode { *; } 

-keepclassmembers class com.rubenwardy.** { *; } 

错误依然,如果我这个替换proguard的发生:

-dontoptimize 
-dontshrink 
-dontusemixedcaseclassnames 
-dontskipnonpubliclibraryclasses 
-dontpreverify 
-verbose 

我绝对有@Subscribe功能MainActivity:

@Subscribe 
protected void onPeriodChange(final Events.PeriodChangeRequestedEvent e) { 
    Log.e("MAct", "Period " + e.from.toString() + " to " + e.to.toString()); 
    filter = new TransactionFilter() { 
     @Override 
     public boolean isAllowed(Transaction transaction) { 
      return transaction.created.getTime() > e.from.getTime() && 
        transaction.created.getTime() < e.to.getTime(); 
     } 
    }; 

    filterTransactions(); 
} 

我有,OFC,一派这一点 - 但无法找到任何结果。 请询问您是否需要更多信息。

+0

'-keep class org.greenrobot.eventbus.Subscribe'怎么样? – Shark

+0

你可以发布你发布这些事件的代码吗? – rhari

回答

1

原来@Subscribe方法需要公开。

@Subscribe 
public void onPeriodChange(final Events.PeriodChangeRequestedEvent e) { 
    Log.e("MAct", "Period " + e.from.toString() + " to " + e.to.toString()); 
    filter = new TransactionFilter() { 
     @Override 
     public boolean isAllowed(Transaction transaction) { 
      return transaction.created.getTime() > e.from.getTime() && 
        transaction.created.getTime() < e.to.getTime(); 
     } 
    }; 

    filterTransactions(); 
} 
相关问题