【问题标题】:How to fix the nullpointerexception that comes up in Eclipse when trying to open an Android XML file?尝试打开 Android XML 文件时如何修复 Eclipse 中出现的空指针异常?
【发布时间】:2012-11-04 10:51:22
【问题描述】:

自从我在 Eclipse 中将 ADT 插件更新到 v1.21 后,我无法再轻松地在我的 Android 项目中打开任何 XML 布局文件。只要我单击该文件,它就会抛出 NullPointerException。以下是错误日志中的堆栈跟踪:

java.lang.NullPointerException
    at com.android.ide.eclipse.adt.internal.editors.common.CommonMatchingStrategy.matches(CommonMatchingStrategy.java:59)
    at org.eclipse.ui.internal.WorkbenchPage.checkEditor(WorkbenchPage.java:2254)
    at org.eclipse.ui.internal.WorkbenchPage.findEditors(WorkbenchPage.java:2223)
    at org.eclipse.ui.internal.WorkbenchPage.findEditor(WorkbenchPage.java:2205)
    at org.eclipse.jdt.internal.ui.javaeditor.EditorUtility.isOpenInEditor(EditorUtility.java:131)
    at org.eclipse.jdt.internal.ui.packageview.PackageExplorerPart.linkToEditor(PackageExplorerPart.java:929)
    at org.eclipse.jdt.internal.ui.packageview.PackageExplorerPart.access$2(PackageExplorerPart.java:926)
    at org.eclipse.jdt.internal.ui.packageview.PackageExplorerPart$4.linkToEditor(PackageExplorerPart.java:533)
    at org.eclipse.ui.OpenAndLinkWithEditorHelper$InternalListener.selectionChanged(OpenAndLinkWithEditorHelper.java:57)
    at org.eclipse.jface.viewers.StructuredViewer$3.run(StructuredViewer.java:888)
    at org.eclipse.core.runtime.SafeRunner.run(SafeRunner.java:42)
    at org.eclipse.ui.internal.JFaceUtil$1.run(JFaceUtil.java:49)
    at org.eclipse.jface.util.SafeRunnable.run(SafeRunnable.java:175)
    at org.eclipse.jface.viewers.StructuredViewer.firePostSelectionChanged(StructuredViewer.java:886)
    at org.eclipse.jface.viewers.StructuredViewer.handlePostSelect(StructuredViewer.java:1226)
    at org.eclipse.jface.viewers.StructuredViewer$5.widgetSelected(StructuredViewer.java:1251)
    at org.eclipse.jface.util.OpenStrategy.firePostSelectionEvent(OpenStrategy.java:262)
    at org.eclipse.jface.util.OpenStrategy.access$5(OpenStrategy.java:256)
    at org.eclipse.jface.util.OpenStrategy$3.run(OpenStrategy.java:433)
    at org.eclipse.swt.widgets.RunnableLock.run(RunnableLock.java:35)
    at org.eclipse.swt.widgets.Synchronizer.runAsyncMessages(Synchronizer.java:135)
    at org.eclipse.swt.widgets.Display.runAsyncMessages(Display.java:4144)
    at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3761)
    at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine$9.run(PartRenderingEngine.java:1029)
    at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:332)
    at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine.run(PartRenderingEngine.java:923)
    at org.eclipse.e4.ui.internal.workbench.E4Workbench.createAndRunUI(E4Workbench.java:86)
    at org.eclipse.ui.internal.Workbench$5.run(Workbench.java:588)
    at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:332)
    at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:543)
    at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:149)
    at org.eclipse.ui.internal.ide.application.IDEApplication.start(IDEApplication.java:124)
    at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:196)
    at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:110)
    at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:79)
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:353)
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:180)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:629)
    at org.eclipse.equinox.launcher.Main.basicRun(Main.java:584)
    at org.eclipse.equinox.launcher.Main.run(Main.java:1438)
    at org.eclipse.equinox.launcher.Main.main(Main.java:1414)

如果我右键单击该文件,我可以打开它,并告诉它无法使用旧版 Android 布局编辑器打开,但这显然不是一个好的解决方案。我尝试进入 Eclipse 首选项,并确保 XML 文件的文件关联设置正确。

【问题讨论】:

  • 看起来完全像一个 Eclipse 错误。我认为您必须与他们一起记录。也许这很常见并且已经在他们的论坛上讨论过?
  • 以前版本中的一些线程在做类似的事情,但似乎没有一个解决方案适用
  • 看起来像 Android 开发者工具中的一个错误。

标签: android xml eclipse nullpointerexception


【解决方案1】:

我通过在编辑器中关闭所有打开的项目文件并重新启动 Eclipse 解决了这个问题。

【讨论】:

  • 为我工作。关闭项目,关闭所有打开的文件,重启Eclipse,打开项目
  • 对我不起作用。此外,当关闭所有项目并重新启动时 - 第一个项目自动重新打开......尝试了几次 - 关闭并重新启动,它会重现。
【解决方案2】:

我切换到一个新的工作区,然后一切正常。

【讨论】:

    猜你喜欢
    • 2020-11-13
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-08-19
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多