Android:无法加载XML

Android:无法加载XML,android,xml,xml-parsing,android-studio,Android,Xml,Xml Parsing,Android Studio,新安卓工作室项目 已创建资产文件夹 创建新活动的构造函数(项目中的第二个),以便在调用活动时读取XML 将要读取的xml文件放在我创建的assets文件夹中 下面是读取xml的代码 AssetManager assetManager = getAssets(); InputStream xmlFile= assetManager.open("menu.xml"); // CREATE BUILDER FACTORY/BUILDER DocumentBuilder

新安卓工作室项目

已创建资产文件夹

创建新活动的构造函数(项目中的第二个),以便在调用活动时读取XML

将要读取的xml文件放在我创建的assets文件夹中

下面是读取xml的代码

    AssetManager assetManager = getAssets();
    InputStream xmlFile= assetManager.open("menu.xml");

    // CREATE BUILDER FACTORY/BUILDER
    DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
    DocumentBuilder builder = factory.newDocumentBuilder();
    Document doc = builder.parse(xmlFile);

    //Element root = doc.getDocumentElement();
    //Log.d("root element",root.getNodeName());

    NodeList list = doc.getElementsByTagName("subcategory");

    Log.d("NODE", String.valueOf(list.getLength()));
运行应用程序时,会调用该按钮以显示新活动,但会崩溃。。。 请帮忙

这里是logcat输出

07-28 15:52:30.138    6990-6990/com.app E/AndroidRuntime﹕ FATAL EXCEPTION: main
    java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.app/com.app.MainMenu}: java.lang.NullPointerException
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1573)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1667)
            at android.app.ActivityThread.access$1500(ActivityThread.java:117)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:935)
            at android.os.Handler.dispatchMessage(Handler.java:99)
            at android.os.Looper.loop(Looper.java:130)
            at android.app.ActivityThread.main(ActivityThread.java:3691)
            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:907)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:665)
            at dalvik.system.NativeStart.main(Native Method)
     Caused by: java.lang.NullPointerException
            at android.content.ContextWrapper.getAssets(ContextWrapper.java:74)
            at com.app.MainMenu.<init>(MainMenu.java:60)
            at java.lang.Class.newInstanceImpl(Native Method)
            at java.lang.Class.newInstance(Class.java:1409)
            at android.app.Instrumentation.newActivity(Instrumentation.java:1021)
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1565)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1667)
            at android.app.ActivityThread.access$1500(ActivityThread.java:117)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:935)
            at android.os.Handler.dispatchMessage(Handler.java:99)
            at android.os.Looper.loop(Looper.java:130)
            at android.app.ActivityThread.main(ActivityThread.java:3691)
            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:907)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:665)
            at dalvik.system.NativeStart.main(Native Method)
07-28 15:52:30.138 6990-6990/com.app E/AndroidRuntime﹕ 致命异常:主
java.lang.RuntimeException:无法实例化活动组件信息{com.app/com.app.main menu}:java.lang.NullPointerException
位于android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1573)
在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1667)上
在android.app.ActivityThread.access,售价1500美元(ActivityThread.java:117)
在android.app.ActivityThread$H.handleMessage(ActivityThread.java:935)上
位于android.os.Handler.dispatchMessage(Handler.java:99)
位于android.os.Looper.loop(Looper.java:130)
位于android.app.ActivityThread.main(ActivityThread.java:3691)
位于java.lang.reflect.Method.Invokenactive(本机方法)
位于java.lang.reflect.Method.invoke(Method.java:507)
在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:907)上
位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:665)
在dalvik.system.NativeStart.main(本机方法)

原因:java.lang.NullPointerException 位于android.content.ContextWrapper.getAssets(ContextWrapper.java:74) 在com.app.MainMenu.(MainMenu.java:60) 位于java.lang.Class.newInstanceImpl(本机方法) 位于java.lang.Class.newInstance(Class.java:1409) 位于android.app.Instrumentation.newActivity(Instrumentation.java:1021) 在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1565)上 在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1667)上 在android.app.ActivityThread.access,售价1500美元(ActivityThread.java:117) 在android.app.ActivityThread$H.handleMessage(ActivityThread.java:935)上 位于android.os.Handler.dispatchMessage(Handler.java:99) 位于android.os.Looper.loop(Looper.java:130) 位于android.app.ActivityThread.main(ActivityThread.java:3691) 位于java.lang.reflect.Method.Invokenactive(本机方法) 位于java.lang.reflect.Method.invoke(Method.java:507) 在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:907)上 位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:665) 在dalvik.system.NativeStart.main(本机方法)
MainACtivity是默认的android studio活动,它带有一个按钮来调用新活动 MainMenu是调用XML的第二个活动

请告知


谢谢大家!

我认为您需要为您的活动所在的任何上下文调用getAssets()


getAssets()

您将资产文件夹放在项目体系结构中的何处?原因是:android.content.ContextWrapper.getAssets(ContextWrapper.java:74)的java.lang.NullPointerException检查getAssets()是否返回一些值。@Rocel assets文件夹是在默认路径src/main/assets(在conf文件app.iml中指定)中创建的@user3586222检查getassets是否返回内容的最佳方法是什么?你能提供代码示例吗?调试项目。我添加了这个。getAssets();同样的问题。