错误日志:
java.lang.IllegalStateException: Fatal Exception thrown on Scheduler.Worker thread.
at rx.internal.schedulers.ScheduledAction.run(ScheduledAction.java:62)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:423)
at java.util.concurrent.FutureTask.run(FutureTask.java:237)
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:269)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1113)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:588)
at java.lang.Thread.run(Thread.java:818)
Caused by: java.lang.AbstractMethodError: abstract method "void rx.functions.Action1.call(java.lang.Object)"
at rx.Observable.unsafeSubscribe(Observable.java:8098)
at rx.internal.operators.OperatorSubscribeOn$1$1.call(OperatorSubscribeOn.java:62)
at rx.internal.schedulers.ScheduledAction.run(ScheduledAction.java:55)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:423)?
at java.util.concurrent.FutureTask.run(FutureTask.java:237)?
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:269)?
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1113)?
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:588)?
at java.lang.Thread.run(Thread.java:818)?
以上是最近在引用自己写的一个jar包后出现的异常问题,jar里面引用到rxAndroid,最终混淆打包使用,混淆文件里面
已经引入了rxAndroid的混淆配置,所以排除了rxAndroid原混淆问题,网上搜的具体答案没找到,但有一个说法引起我
的注意,就是匿名内部类混淆问题,然后再仔细看下异常日志
Caused by: java.lang.AbstractMethodError: abstract method "void rx.functions.Action1.call(java.lang.Object)"
这里提到的方法就是一个匿名内部类方法,然后再仔细看了下混淆的jar包里面有使用到这个方法的地方
Observable.create(new int(this)).subscribeOn(Schedulers.io()).subscribe();
这整一块是没有混淆的,也就是说,create里面的call方法名不能被混淆,否则就无法被调用,一旦混淆就会出现抽象方法未
被实现的异常然后去核实下这个对象是否被混淆了,如下
final class if
implements Observable.OnSubscribe
{
if(do paramdo)
{ }
private void jdMethod_do()
{}
}
虽然实现的没有变,但里面的方法名已经变了,以至于提示abstractMethodError,核心问题找到了,就是keep住方法名就可以了。
在jar混淆文件里面加入
-keep class com.**.xxxxx$* {
public <methods>;
}
上面是keep xxx 类里面的所有内部类方法,本来是想keep某个特定的类的(类型上述情况的类),可惜试了很久都没成功,
如有人知道,麻烦留言告知,同时小编也继续测试!!