Java 当三星Galaxy Tab 4 7.0第二次(或后续)呼叫camera intent时,应用程序崩溃

Java 当三星Galaxy Tab 4 7.0第二次(或后续)呼叫camera intent时,应用程序崩溃,java,android,android-studio,android-camera-intent,Java,Android,Android Studio,Android Camera Intent,使用Android Studio 1.0,我有一个带有listview的活动,它使用适配器显示自定义布局。“setOnItemClickListener”调用一个相机意图,它在第一次运行时就可以完美地工作——“onActivityResult”检索图像,发布图像,删除文件并回收内存(内存监视器确认GB在此正常工作)。第二次启动时,应用程序在“startActivityForResult”调用后崩溃 LogCat报告它找不到与我的自定义布局对应的资源id#0x7f030012。让我困惑的是,为什么

使用Android Studio 1.0,我有一个带有listview的活动,它使用适配器显示自定义布局。“setOnItemClickListener”调用一个相机意图,它在第一次运行时就可以完美地工作——“onActivityResult”检索图像,发布图像,删除文件并回收内存(内存监视器确认GB在此正常工作)。第二次启动时,应用程序在“startActivityForResult”调用后崩溃

LogCat报告它找不到与我的自定义布局对应的资源id#0x7f030012。让我困惑的是,为什么在第二次调用“startActivityForResult”方法时会触发“doCallbacks”和“onMeasure”事件

该应用程序在Titan和三星Galaxy S3设备上运行良好,但在定制平板电脑4.4.4 API 19(2560 x 1600)仿真器和Galaxy Tab 4 7.0设备上失败


清单代码段:

<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
日志:

12-11 13:10:38.539 4122-4122/com.company.product W/ResourceType﹕ 获取包0中0x7f030012(t=2 e=18)的条目失败(错误 -75)12-11 13:10:38.539 4122-4122/com.company.product D/AndroidRuntime﹕ 正在关闭VM 12-11 13:10:38.539
4122-4122/com.company.product W/dalvikvm﹕ threadid=1:线程正在退出 有未捕获的异常(组=0x41769c08)12-11 13:10:38.579
4122-4122/com.opsi.zeno E/AndroidRuntime﹕ 致命异常:主 进程:com.opsi.zeno,PID:4122 android.content.res.Resources$NotFoundException:资源ID#0x7f030012 位于android.content.res.Resources.getValue(Resources.java:2350) 位于android.content.res.Resources.loadXmlResourceParser(Resources.java:3678) 位于android.content.res.Resources.getLayout(Resources.java:2166) 在android.view.LayoutInflater.inflate(LayoutInflater.java:396) 位于com.company.product.adapters.WorkflowAdapter.getView(WorkflowAdapter.java:60) 在android.widget.AbsListView.obtainView(AbsListView.java:2738) 在android.widget.ListView.measureHeightOChildren(ListView.java:1274)上 在android.widget.ListView.onMeasure(ListView.java:1186)上 在android.view.view.measure(view.java:17478) 位于android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5363) 位于android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1410) 位于android.widget.LinearLayout.measureVertical(LinearLayout.java:695) 位于android.widget.LinearLayout.onMeasure(LinearLayout.java:588) 在android.view.view.measure(view.java:17478) 位于android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5363) 位于android.widget.FrameLayout.onMeasure(FrameLayout.java:310) 在android.view.view.measure(view.java:17478) 位于android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5363) 位于com.android.internal.widget.ActionBarOverlayLayout.onMeasure(ActionBarOverlayLayout.java:412) 在android.view.view.measure(view.java:17478) 位于android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5363) 位于android.widget.FrameLayout.onMeasure(FrameLayout.java:310) 在com.android.internal.policy.impl.PhoneWindow$DecorView.onMeasure上(PhoneWindow.java:2548) 在android.view.view.measure(view.java:17478) 在android.view.ViewRootImpl.performMeasure上(ViewRootImpl.java:2285) 在android.view.ViewRootImpl.measureHierarchy(ViewRootImpl.java:1396) 在android.view.ViewRootImpl.performTraversals上(ViewRootImpl.java:1595) 位于android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1254) 在android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:6624) 在android.view.Choreographer$CallbackRecord.run(Choreographer.java:812) 位于android.view.Choreographer.doCallbacks(Choreographer.java:612) 位于android.view.Choreographer.doFrame(Choreographer.java:582) 在android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:798)上 位于android.os.Handler.handleCallback(Handler.java:733) 位于android.os.Handler.dispatchMessage(Handler.java:95) 位于android.os.Looper.loop(Looper.java:146) 位于android.app.ActivityThread.main(ActivityThread.java:5602) 位于java.lang.reflect.Method.Invokenactive(本机方法) 位于java.lang.reflect.Method.invoke(Method.java:515) 在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1283)上 位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1099) 在dalvik.system.NativeStart.main(本机方法)


结果证明这是某种线程问题。我在“startActivityForResult()”执行代码中添加了一个延迟,它解决了这个问题。这与其说是一个恰当的解决方案,不如说是一个黑客行为,也许有人可以解释一下这个问题,即为什么安卓在新活动启动时会启动当前活动的线程

Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
intent.putExtra(MediaStore.EXTRA_OUTPUT, fileUri);
startActivityForResult(intent, CAPTURE_IMAGE_ACTIVITY_REQUEST_CODE);