【问题标题】:Android - error opening trace file: No such file or directoryAndroid - 打开跟踪文件时出错:没有这样的文件或目录
【发布时间】:2013-02-07 14:42:50
【问题描述】:

我收到了一个奇怪的错误列表,其中一些似乎已断开连接,但我无法判断,因为我什至无法加载我的应用程序以进行调试。这是一个非常简单的应用程序,一个单选按钮组中有 3 个单选按钮,每个单选按钮都会触发不同的歌曲播放。

我将首先发布我的清单、我的活动文件和布局,然后发布错误日志。

清单:

    <manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.cis298.lab2"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="17" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >

        <activity 
            android:label = "@string/app_name"
            android:name = ".LayoutActivity">
            <intent-filter >
                <action android:name = "android.intent.action.MAIN" />

                <category android:name = "android.intent.category.LAUNCHER" />

            </intent-filter>
            ></activity>
    </application>

</manifest>

布局活动:

package com.cis298.lab2;

import java.io.IOException;

import com.cis298.lab2.R;

import android.app.Activity;
import android.os.Bundle;
import android.media.MediaPlayer;
import android.widget.RadioGroup;

public class LayoutActivity extends Activity {

    int song;
    MediaPlayer mediaplayer = MediaPlayer.create(this, song);

    public void onCreate(Bundle savedInstanceState){
        super.onCreate(savedInstanceState);
        setContentView(R.layout.layout);
        try {
            mediaplayer.prepare();
        } catch (IllegalStateException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        RadioGroup radgrp = (RadioGroup) findViewById(R.id.radiogroup);
        radgrp.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {

            @Override
            public void onCheckedChanged(RadioGroup group, int checkedId) {
                switch (checkedId){
                case R.id.dance:
                    song = R.raw.redalert;
                    mediaplayer.start();
                    break;
                case R.id.rap:
                    song = R.raw.cannedheat;
                    break;
                case R.id.rock:
                    song = R.raw.movmou8105;
                    break;}
            }
        });
    }
}

布局:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

   <RadioGroup
       android:id="@+id/radiogroup"
       android:layout_width="match_parent"
       android:layout_height="match_parent"
       android:layout_alignParentLeft="true"
       android:layout_alignParentTop="true"
       android:orientation="vertical" >

       <RadioButton
           android:id="@+id/rock"
           android:layout_width="wrap_content"
           android:layout_height="wrap_content"
           android:text="Play Rock" />

       <RadioButton
           android:id="@+id/rap"
           android:layout_width="wrap_content"
           android:layout_height="wrap_content"
           android:text="Play Rap" 
           android:checked="true"/>

       <RadioButton
           android:id="@+id/dance"
           android:layout_width="fill_parent"
           android:layout_height="wrap_content"
           android:text="Play Dance"
           android:textAlignment="center" />

   </RadioGroup>

</RelativeLayout>

日志:

02-21 20:34:05.044: D/AndroidRuntime(322): 关闭 VM 02-21 20:34:05.044: W/dalvikvm(322): threadid=1: 线程退出 未捕获的异常(组=0x4001d800)02-21 20:34:05.094: E/AndroidRuntime(322): 致命异常: main 02-21 20:34:05.094: E/AndroidRuntime(322): java.lang.RuntimeException: 无法 实例化活动 组件信息{com.cis298.lab2/com.cis298.lab2.LayoutActivity}: java.lang.NullPointerException 02-21 20:34:05.094: E/AndroidRuntime(322):在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2585) 02-21 20:34:05.094: E/AndroidRuntime(322): 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679) 02-21 20:34:05.094: E/AndroidRuntime(322): 在 android.app.ActivityThread.access$2300(ActivityThread.java:125) 02-21 20:34:05.094: E/AndroidRuntime(322): 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033) 02-21 20:34:05.094: E/AndroidRuntime(322): 在 android.os.Handler.dispatchMessage(Handler.java:99) 02-21 20:34:05.094: E/AndroidRuntime(322): 在 android.os.Looper.loop(Looper.java:123) 02-21 20:34:05.094: E/AndroidRuntime(322):在 android.app.ActivityThread.main(ActivityThread.java:4627) 02-21 20:34:05.094: E/AndroidRuntime(322): 在 java.lang.reflect.Method.invokeNative(Native Method) 02-21 20:34:05.094: E/AndroidRuntime(322): 在 java.lang.reflect.Method.invoke(Method.java:521) 02-21 20:34:05.094: E/AndroidRuntime(322):在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868) 02-21 20:34:05.094: E/AndroidRuntime(322): 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626) 02-21 20:34:05.094: E/AndroidRuntime(322): 在 dalvik.system.NativeStart.main(本机方法)02-21 20:34:05.094: E/AndroidRuntime(322):引起:java.lang.NullPointerException 02-21 20:34:05.094: E/AndroidRuntime(322): 在 android.content.ContextWrapper.getResources(ContextWrapper.java:80) 02-21 20:34:05.094: E/AndroidRuntime(322): 在 android.media.MediaPlayer.create(MediaPlayer.java:641) 02-21 20:34:05.094: E/AndroidRuntime(322): 在 com.cis298.lab2.LayoutActivity.(LayoutActivity.java:15) 02-21 20:34:05.094: E/AndroidRuntime(322): 在 java.lang.Class.newInstanceImpl(本机方法)02-21 20:34:05.094: E/AndroidRuntime(322):在 java.lang.Class.newInstance(Class.java:1429) 02-21 20:34:05.094: E/AndroidRuntime(322):在 android.app.Instrumentation.newActivity(Instrumentation.java:1021) 02-21 20:34:05.094: E/AndroidRuntime(322): 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2577) 02-21 20:34:05.094: E/AndroidRuntime(322): ... 11 更多

任何帮助将不胜感激。

【问题讨论】:

  • 您尚未在活动中初始化某些内容。这就是我能说的!
  • LayoutActivity.java 的第 15 行是什么?
  • 顺便说一句,在我删除的关闭活动标签之前有一个额外的 >,但我仍然收到相同的错误。
  • 第 15 行是 MediaPlayer mediaplayer = MediaPlayer.create(this, song);

标签: java android nullpointerexception runtime android-mediaplayer


【解决方案1】:

尝试将mediaplayer = MediaPlayer.create(this, song); 移动到内部onCreate()

由于 Activity 直到 onCreate() 才完全初始化,这可能是 NPE 的原因。

然而,下一个问题是您创建 MediaPlayer 时歌曲最初为 0(当它是实例时,int 的默认值为 0多变的)。因此,如果移动 MediaPlayer.create 解决了 this NPE,则下一个错误将是无法找到资源。因此,一旦song 持有有用的内容,请致电MediaPlayer.create

也许这样的事情会起作用。

public class LayoutActivity extends Activity {

  int song;
  MediaPlayer mediaPlayer;

  public void onCreate(Bundle savedInstanceState){
    super.onCreate(savedInstanceState);
    setContentView(R.layout.layout);

    RadioGroup radgrp = (RadioGroup) findViewById(R.id.radiogroup);
    radgrp.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {

      @Override
      public void onCheckedChanged(RadioGroup group, int checkedId) {
        switch (checkedId){
          case R.id.dance:
            song = R.raw.redalert;
            break;
          case R.id.rap:
            song = R.raw.cannedheat;
            break;
          case R.id.rock:
            song = R.raw.movmou8105;
            break;
        }


        mediaplayer = MediaPlayer.create(LayoutActivity.this, song);
        try {
          mediaplayer.prepare();
          mediaplayer.start();
        } catch (IllegalStateException e) {
          // TODO Auto-generated catch block
          e.printStackTrace();
        } catch (IOException e) {
          // TODO Auto-generated catch block
          e.printStackTrace();
        }
      }
    });
  }
}

如果歌曲没有在其他地方使用,您可以将其保留在onCheckedChanged()的范围内。

【讨论】:

  • 这是我的问题(必须将其移到 onCreate 方法中)。此外,每次上传 APK 都需要 5 分钟以上的时间。我调查了一下,人们抱怨大约 90 秒,所以一定是真的有问题,知道吗?
  • 我们都是新手,你的问题很好而且详细:-) 对于新用户,如果他们说我的回答正确,我总是链接到那个元问题,因为并非所有人都熟悉如何SO 的作品。无论如何,欢迎!
猜你喜欢
  • 2012-07-11
  • 1970-01-01
  • 1970-01-01
  • 2013-06-22
  • 2013-07-22
  • 1970-01-01
相关资源
最近更新 更多