Android模式策略

Android模式策略,android,android-strictmode,Android,Android Strictmode,android应用程序遇到了一些ANR问题,所以我实施了StrictMode策略。以前从未使用过此功能,因此希望有人能帮助解释以下内容: 为什么日志中显示了两个看似相似的违规行为,除了前4行和持续时间的差异之外?为什么会有两个违规-这是否意味着代码被执行了两次 谢谢你的帮助 08-15 14:24:14.314: DEBUG/StrictMode(767): StrictMode policy violation; ~duration=13876 ms: android.os.StrictMod

android应用程序遇到了一些ANR问题,所以我实施了StrictMode策略。以前从未使用过此功能,因此希望有人能帮助解释以下内容:

为什么日志中显示了两个看似相似的违规行为,除了前4行和持续时间的差异之外?为什么会有两个违规-这是否意味着代码被执行了两次

谢谢你的帮助

08-15 14:24:14.314: DEBUG/StrictMode(767): StrictMode policy violation; ~duration=13876 ms: android.os.StrictMode$StrictModeDiskWriteViolation: policy=17 violation=1
    at android.os.StrictMode$AndroidBlockGuardPolicy.onWriteToDisk(StrictMode.java:732)
    at android.database.sqlite.SQLiteDatabase.execSQL(SQLiteDatabase.java:1791)
    at com.j256.ormlite.android.AndroidCompiledStatement.execSql(AndroidCompiledStatement.java:151)
    at com.j256.ormlite.android.AndroidCompiledStatement.runUpdate(AndroidCompiledStatement.java:70)
    at com.j256.ormlite.stmt.StatementExecutor.update(StatementExecutor.java:382)
    at com.j256.ormlite.dao.BaseDaoImpl.update(BaseDaoImpl.java:374)
    at conx.Repositories.JobRepository.update(JobRepository.java:381)
    at conx.Presenters.JobSchedulePresenter.onSave(JobSchedulePresenter.java:200)
    at conx.Activities.JobScheduleActivity.onSaveEvent(JobScheduleActivity.java:111)
    at conx.Activities.JobScheduleActivity.access$100(JobScheduleActivity.java:43)
    at conx.Activities.JobScheduleActivity$2.onChildClick(JobScheduleActivity.java:169)
    at android.widget.ExpandableListView.handleItemClick(ExpandableListView.java:588)
    at android.widget.ExpandableListView.performItemClick(ExpandableListView.java:527)
    at android.widget.AbsListView$PerformClick.run(AbsListView.java:1877)
    at android.os.Handler.handleCallback(Handler.java:587)
    at android.os.Handler.dispatchMessage(Handler.java:92)
    at android.os.Looper.loop(Looper.java:130)
    at android.app.ActivityThread.main(ActivityThread.java:3835)
    at java.lang.reflect.Method.invokeNative(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:507)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:864)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:622)
    at dalvik.system.NativeStart.main(Native Method)

 08-15 14:24:14.314: DEBUG/StrictMode(767): StrictMode policy violation; ~duration=12086 ms: android.os.StrictMode$StrictModeDiskWriteViolation: policy=17 violation=1
    at android.os.StrictMode$AndroidBlockGuardPolicy.onWriteToDisk(StrictMode.java:732)
    at android.database.sqlite.SQLiteStatement.execute(SQLiteStatement.java:52)
    at android.database.sqlite.SQLiteDatabase.execSQL(SQLiteDatabase.java:1809)
    at com.j256.ormlite.android.AndroidCompiledStatement.execSql(AndroidCompiledStatement.java:151)
    at com.j256.ormlite.android.AndroidCompiledStatement.runUpdate(AndroidCompiledStatement.java:70)
    at com.j256.ormlite.stmt.StatementExecutor.update(StatementExecutor.java:382)
    at com.j256.ormlite.dao.BaseDaoImpl.update(BaseDaoImpl.java:374)
    at conx.Repositories.JobRepository.update(JobRepository.java:381)
    at conx.Presenters.JobSchedulePresenter.onSave(JobSchedulePresenter.java:200)
    at conx.Activities.JobScheduleActivity.onSaveEvent(JobScheduleActivity.java:111)
    at conx.Activities.JobScheduleActivity.access$100(JobScheduleActivity.java:43)
    at conx.Activities.JobScheduleActivity$2.onChildClick(JobScheduleActivity.java:169)
    at android.widget.ExpandableListView.handleItemClick(ExpandableListView.java:588)
    at android.widget.ExpandableListView.performItemClick(ExpandableListView.java:527)
    at android.widget.AbsListView$PerformClick.run(AbsListView.java:1877)
    at android.os.Handler.handleCallback(Handler.java:587)
    at android.os.Handler.dispatchMessage(Handler.java:92)
    at android.os.Looper.loop(Looper.java:130)
    at android.app.ActivityThread.main(ActivityThread.java:3835)
    at java.lang.reflect.Method.invokeNative(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:507)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:864)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:622)
    at dalvik.system.NativeStart.main(Native Method)

StrictMode冲突显示您正在UI线程上执行SQLite查询,这导致了ANR问题

尝试在单独的线程上执行数据库交互,这将防止ANR问题,并防止出现这些StrictMode冲突

通过浏览
LogCat
输出,它看起来像是发生在
conx.Activities.JobScheduleActivity.onSaveEvent

一些有用的阅读: