java.lang.IllegalStateException解决合集

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;

@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

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

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

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

持续更新中......

猜你喜欢

转载自blog.csdn.net/luoro/article/details/127905656