1、跑monkey时报错,只定位到了是哪一个模块出的问题,但没有定位代码位置,大概是指Handler的问题

java.lang.IllegalStateException

The specified message queue synchronization barrier token has not been posted or has already been removed. android.os.MessageQueue.removeSyncBarrier(MessageQueue.java:587)

因为没有定位到代码中的具体位置,所以我搜了一下网上的解决方案,google翻译给出的结果是:指定的消息队列同步屏障令牌尚未发布或已经被删除。大概是指Handler的问题。

所以可以尝试一下以下解法:

解决1

原因:在线程中向主线程发消息时使用的Message对象已经被发送过(通俗来讲就是Message对象被重用了)。

解决:在每次发送message前都new一个新的message对象

tips: 可以看一下Massege msg1=new Message() 、Massege msg2=Message.obtain()、

Message msg3 = Handler.obtainMessage()的区别

解决2:

在handlerMessage()方法中添加this.obtainMessage()

(这个解决方法没有尝试,而且答者也没有给出具体原因)

解决3:

原因:因为子线程刷新UI引起

private HandlerThread mHandlerThread;private Handler mHandler;@Overridepublic void onCreate(@Nullable Bundle savedInstanceState) {super.onCreate(savedInstanceState);mHandlerThread = new HandlerThread(TAG);mHandlerThread.start();mHandler = new Handler(mHandlerThread.getLooper()); //子线程中有looper}public void initView(){ mAnimation.setAnimationListener(new Animation.AnimationListener() {@Overridepublic void onAnimationStart(Animation animation){mHandler.postDelayed(()->{showAnination();},500);//在子线程中刷新了UI.... }

(学徒浅谈Android——从HandlerThread谈myLooper()和getMainLooper() – 程序员大本营)可以看一下这篇,解释了为什么是子线程

解决:

(记录一个Android崩溃 MessageQueue – 掘金)这位答主给的解决方案是判断是否在子线程,如果在子线程则post到主线程

其实也可以直接重新在主线程new一个新的handler,使用这个新的handler去刷新UI

2、java.lang.IllegalStateException导致了crash,报错位置定位到了代码中handleMassge方法中

可以尝试一下捕获这个IllegalStateException异常

@Overridepublic void handleMessage(@NonNull Message msg) {super.handleMessage(msg);if (msg.what == 1) {try {....} catch (IOException | IllegalStateException ex) {ex.printStackTrace();}}}

持续更新中……