Я работаю над внутренним приложением, которое отображает ежедневное расписание для данного конференц-зала на временной шкале.Каждую минуту я обращаюсь к веб-службе и получаю информацию обо всех встречах за день, и я использую эти данные для создания пользовательских представлений «временной шкалы», которые показывают время встречи, клиента и т. Д. Затем я удаляю все встречиот графика и обновите его новыми данными.Пользовательские представления, которые я использую, состоят не более чем из LinearLayout с тремя TextViews внутри.Полагаю, я должен заметить, что макет действия довольно сложный, а некоторые представления вложены примерно в 7 слоев.
Все работает отлично в течение 2-3 дней, а затем приложение вылетает.Я сделал так, чтобы он попадал в веб-сервис каждые 3 секунды, и теперь сбой будет происходить примерно каждые 2,5 часа.Что меня привлекает, так это то, что выбрасываемое исключение даже не указывает ни на что в моем коде.Ниже приведено исключение:
FATAL EXCEPTION: main
java.lang.ClassCastException: java.lang.String
at android.text.Styled.drawDirectionalRun(Styled.java:283)
at android.text.Styled.measureText(Styled.java:430)
at android.text.Layout.measureText(Layout.java:1655)
at android.text.Layout.getLineMax(Layout.java:689)
at android.text.Layout.getLineWidth(Layout.java:671)
at android.widget.TextView.desired(TextView.java:5037)
at android.widget.TextView.onMeasure(TextView.java:5083)
at android.view.View.measure(View.java:8171)
at android.widget.RelativeLayout.measureChildHorizontal(RelativeLayout.java:578)
at android.widget.RelativeLayout.onMeasure(RelativeLayout.java:362)
at android.view.View.measure(View.java:8171)
at android.widget.RelativeLayout.measureChildHorizontal(RelativeLayout.java:578)
at android.widget.RelativeLayout.onMeasure(RelativeLayout.java:362)
at android.view.View.measure(View.java:8171)
at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:3132)
at android.widget.FrameLayout.onMeasure(FrameLayout.java:245)
at android.view.View.measure(View.java:8171)
at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:3132)
at android.widget.FrameLayout.onMeasure(FrameLayout.java:245)
at android.view.View.measure(View.java:8171)
at android.view.ViewRoot.performTraversals(ViewRoot.java:801)
at android.view.ViewRoot.handleMessage(ViewRoot.java:1727)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:123)
at android.app.ActivityThread.main(ActivityThread.java:4627)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:521)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
at dalvik.system.NativeStart.main(Native Method)
Если я неправильно разыгрываю строку (а я уверен, что нет), как получается, что она не будет перехвачена до тех пор, пока не станет настолько глубоко в нативном коде?Я в недоумении здесь.Возможно ли, что это внутренняя ошибка Android?
Еще одна вещь, которая может помочь: в другой раз, когда это приложение рухнуло, оно выдало такое же ClassCastException, но в другом месте.Это произошло в функции BoringLayout.isBoring
, которая также никогда не затрагивалась в моем коде.