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的问题。
所以可以尝试一下以下解法:
原因:在线程中向主线程发消息时使用的Message对象已经被发送过(通俗来讲就是Message对象被重用了)。
解决:在每次发送message前都new一个新的message对象
tips: 可以看一下Massege msg1=new Message() 、Massege msg2=Message.obtain()、
Message msg3 = Handler.obtainMessage()的区别
在handlerMessage()方法中添加this.obtainMessage()
(这个解决方法没有尝试,而且答者也没有给出具体原因)
原因:因为子线程刷新UI引起
private HandlerThread mHandlerThread;
private Handler mHandler;
@Override
public 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() {
@Override
public void onAnimationStart(Animation animation){
mHandler.postDelayed(()->{
showAnination();
},500); //在子线程中刷新了UI
....
}
(学徒浅谈Android——从HandlerThread谈myLooper()和getMainLooper() - 程序员大本营)可以看一下这篇,解释了为什么是子线程
解决:
(记录一个Android崩溃 MessageQueue - 掘金)这位答主给的解决方案是判断是否在子线程,如果在子线程则post到主线程
其实也可以直接重新在主线程new一个新的handler,使用这个新的handler去刷新UI
可以尝试一下捕获这个IllegalStateException异常
@Override
public void handleMessage(@NonNull Message msg) {
super.handleMessage(msg);
if (msg.what == 1) {
try {
....
} catch (IOException | IllegalStateException ex) {
ex.printStackTrace();
}
}
}
持续更新中......