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();}}}
持续更新中……