首先,对不起我的英语不好。我是 android 新手,但我可以解决一些 logcat 问题,比如 classnotfoundexception ecc。但是那个,我真的看不懂。一段时间以来,eclipse 开始做一些非常奇怪的事情。首先,当我尝试打开它时,它会弹出一个窗口说“这个Android SDK需要Android Developer Toolkit 21.1.0或更高版本。当前版本是21.0.1.2012-12-6-2-58。请将ADT更新到最新版本版本”。所以我点击“检查更新”,过了一会儿它出现了另一个窗口,上面写着“没有找到更新”。哦,很酷,它要求我更新,但他找不到更新。
但无论如何:在我关闭它之后,它会立即在错误日志中向我显示这个错误:“未处理的事件循环执行”。我双击它,它似乎是:
java.lang.NullPointerException
at com.android.ide.eclipse.adt.internal.wizards.newxmlfile.NewXmlFileCreationPage.updateAvailableTypes(NewXmlFileCreationPage.java:1062)
at com.android.ide.eclipse.adt.internal.wizards.newxmlfile.NewXmlFileCreationPage.createControl(NewXmlFileCreationPage.java:536)
at org.eclipse.jface.wizard.Wizard.createPageControls(Wizard.java:174)
at org.eclipse.jface.wizard.WizardDialog.createPageControls(WizardDialog.java:736)
at org.eclipse.jface.wizard.WizardDialog.createContents(WizardDialog.java:608)
at org.eclipse.jface.window.Window.create(Window.java:431)
at org.eclipse.jface.dialogs.Dialog.create(Dialog.java:1089)
at org.eclipse.ui.internal.actions.NewWizardShortcutAction.run(NewWizardShortcutAction.java:122)
at org.eclipse.jface.action.Action.runWithEvent(Action.java:498)
at org.eclipse.jface.action.ActionContributionItem.handleWidgetSelection(ActionContributionItem.java:584)
at org.eclipse.jface.action.ActionContributionItem.access$2(ActionContributionItem.java:501)
at org.eclipse.jface.action.ActionContributionItem$5.handleEvent(ActionContributionItem.java:411)
at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:84)
at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1053)
at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:4169)
at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3758)
at org.eclipse.ui.internal.Workbench.runEventLoop(Workbench.java:2701)
at org.eclipse.ui.internal.Workbench.runUI(Workbench.java:2665)
at org.eclipse.ui.internal.Workbench.access$4(Workbench.java:2499)
at org.eclipse.ui.internal.Workbench$7.run(Workbench.java:679)
at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:332)
at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:668)
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)
会话数据:
eclipse.buildId=v21.0.1-543035
java.version=1.7.0_10
java.vendor=Oracle Corporation
BootLoader constants: OS=win32, ARCH=x86_64, WS=win32, NL=it_IT
Framework arguments: -product com.android.ide.eclipse.adt.package.product
Command-line arguments: -os win32 -ws win32 -arch x86_64 -product com.android.ide.eclipse.adt.package.product
This is a continuation of log file C:/XXXXX
Created Time: 2013-03-23 14:54:10.477
我不知道这意味着什么,但看起来这不是项目本身的代码错误。
另外,第一次发生这个问题时,我打开了 SDK 管理器,我看到我之前下载的所有文件都不再安装了。无论如何,在我重新安装它们之后,有时(但由于某种奇怪的原因并非总是如此)一些安装的 sdk 需要更新(即使我在一两天前更新了它们)。
但现在最大的问题是:我所有的项目类都报告错误:它们无法识别诸如 floatmath 或 opengl es 矩阵等之类的东西(甚至是类名之类的愚蠢的东西);如果我检查看起来没有错误的类(通过包资源管理器中的类图像,它通常会在类名称的左侧弹出一个红十字),无论如何都会有错误和甚至非常愚蠢(例如:@Override 无法解析为类型......什么?!)。
这不是我的错:在那个烦人的问题突然出现之前,我多次启动了我的所有项目,它们工作得非常好,嗯。
最后一件事:当我将某些内容保存在 xml 文件中时(呃另一个问题:布局文件夹中的主要内容消失了......),它显示:
“'运行 Android Lint' 遇到问题。失败”。我单击详细信息,它显示“失败的 java.lang.NullPointerException”。如果我检查错误日志,它会向我显示:“失败”。如果我双击它,如果显示我:
java.lang.NullPointerException
at com.android.ide.eclipse.adt.internal.lint.EclipseLintClient.getTargets(EclipseLintClient.java:890)
at com.android.tools.lint.client.api.LintClient.getHighestKnownApiLevel(LintClient.java:609)
at com.android.tools.lint.client.api.LintDriver$LintClientWrapper.getHighestKnownApiLevel(LintDriver.java:1751)
at com.android.tools.lint.checks.ManifestOrderDetector.visitElement(ManifestOrderDetector.java:396)
at com.android.tools.lint.client.api.XmlVisitor.visitElement(XmlVisitor.java:170)
at com.android.tools.lint.client.api.XmlVisitor.visitElement(XmlVisitor.java:209)
at com.android.tools.lint.client.api.XmlVisitor.visitFile(XmlVisitor.java:150)
at com.android.tools.lint.client.api.LintDriver.runFileDetectors(LintDriver.java:806)
at com.android.tools.lint.client.api.LintDriver.checkProject(LintDriver.java:732)
at com.android.tools.lint.client.api.LintDriver.analyze(LintDriver.java:340)
at com.android.ide.eclipse.adt.internal.lint.LintJob.run(LintJob.java:153)
at org.eclipse.core.internal.jobs.Worker.run(Worker.java:54)
会话数据:
Framework arguments: -product com.android.ide.eclipse.adt.package.product
Command-line arguments: -os win32 -ws win32 -arch x86_64 -product com.android.ide.eclipse.adt.package.productFramework arguments: -product com.android.ide.eclipse.adt.package.product
Command-line arguments: -os win32 -ws win32 -arch x86_64 -product com.android.ide.eclipse.adt.package.product
所以有什么问题?我按照这里写的方式尝试了当我加载 ADT 时为什么会收到错误“Android SDK 需要 Android Developer Toolkit 版本 XX.XX 或更高版本?” ,但在那之后,android XML 像魔术一样消失了。
谁能帮我?