所以我试图理解如何反应以及如何使用Room库,但我得到了一些异常,我不知道如何解决:
08-11 20:35:44.349 8797-8797/ru.android_school.h_h.eightapp W/System.err: io.reactivex.exceptions.OnErrorNotImplementedException: Cannot access database on the main thread since it may potentially lock the UI for a long period of time.
at io.reactivex.internal.functions.Functions$OnErrorMissingConsumer.accept(Functions.java:704)
at io.reactivex.internal.functions.Functions$OnErrorMissingConsumer.accept(Functions.java:701)
at io.reactivex.internal.subscribers.LambdaSubscriber.onError(LambdaSubscriber.java:79)
at io.reactivex.internal.subscribers.LambdaSubscriber.onNext(LambdaSubscriber.java:69)
08-11 20:35:44.350 8797-8797/ru.android_school.h_h.eightapp W/System.err: at io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.onNext(FlowableSubscribeOn.java:97)
at io.reactivex.internal.operators.flowable.FlowableObserveOn$ObserveOnSubscriber.runAsync(FlowableObserveOn.java:400)
at io.reactivex.internal.operators.flowable.FlowableObserveOn$BaseObserveOnSubscriber.run(FlowableObserveOn.java:176)
at io.reactivex.android.schedulers.HandlerScheduler$ScheduledRunnable.run(HandlerScheduler.java:109)
at android.os.Handler.handleCallback(Handler.java:808)
at android.os.Handler.dispatchMessage(Handler.java:101)
at android.os.Looper.loop(Looper.java:166)
at android.app.ActivityThread.main(ActivityThread.java:7425)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:245)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:921)
Caused by: java.lang.IllegalStateException: Cannot access database on the main thread since it may potentially lock the UI for a long period of time.
08-11 20:35:44.351 8797-8797/ru.android_school.h_h.eightapp W/System.err: at android.arch.persistence.room.RoomDatabase.assertNotMainThread(RoomDatabase.java:204)
at android.arch.persistence.room.RoomDatabase.query(RoomDatabase.java:232)
at ru.android_school.h_h.eightapp.note_trio.NoteDao_Impl.getBySearch(NoteDao_Impl.java:230)
at ru.android_school.h_h.eightapp.note_list.ListActivity$1.onMenuItemActionCollapse(ListActivity.java:59)
at android.support.v7.view.menu.MenuItemImpl.collapseActionView(MenuItemImpl.java:841)
at ru.android_school.h_h.eightapp.note_list.ListActivity$4.accept(ListActivity.java:111)
at ru.android_school.h_h.eightapp.note_list.ListActivity$4.accept(ListActivity.java:107)
at io.reactivex.internal.subscribers.LambdaSubscriber.onNext(LambdaSubscriber.java:65)
... 11 more在MainActivity的onCreate()中由以下原因引起:
db.noteDao()
.getAllLive()
.observeOn(AndroidSchedulers.mainThread())
.subscribeOn(Schedulers.io())
.subscribe(new Consumer<List<Note>>() {
@Override
public void accept(List<Note> notes) throws Exception {
progressDialog.dismiss();
searchMenuItem.collapseActionView();
listOfNotes.clear();
listOfNotes.addAll(notes);
listAdapter.notifyDataSetChanged();
if (listOfNotes.size() != 0) {
findViewById(R.id.emptyListReplacer).setVisibility(View.INVISIBLE);
} else {
findViewById(R.id.emptyListReplacer).setVisibility(View.VISIBLE);
}
}
});其中db显然是实现Dao接口的数据库和noteDao。我刚接触反应式编程和多线程,但我不知道如何解决它。请帮帮忙?
更新:在databaseBuilder中使用.allowMainThreadQueries()解决了这个问题,但据我所知,这是解决问题的错误方法。
发布于 2018-08-12 17:32:35
异常不是由这段代码引起的。问题出在方法insert()和getBySearch()中,我在问题中没有指定它们。
https://stackoverflow.com/questions/51801505
复制相似问题