0
06-06 10:06:22.404: I/System.out(418): Files:[Ljava.io.File;@406f43a8
06-06 10:06:22.414: I/System.out(418): List all Items:[/sdcard/MyVideo, /sdcard/.android_secure]
06-06 10:06:22.414: I/System.out(418): Files:[Ljava.io.File;@406f43a8
06-06 10:06:22.414: I/System.out(418): List all Items:[/sdcard/MyVideo, /sdcard/.android_secure, /sdcard/LOST.DIR]
06-06 10:06:22.414: D/AndroidRuntime(418): Shutting down VM
06-06 10:06:22.414: W/dalvikvm(418): threadid=1: thread exiting with uncaught exception (group=0x40014760)
06-06 10:06:22.434: E/AndroidRuntime(418): FATAL EXCEPTION: main
06-06 10:06:22.434: E/AndroidRuntime(418): java.lang.IllegalStateException: System services not available to Activities before onCreate()
06-06 10:06:22.434: E/AndroidRuntime(418):  at android.app.Activity.getSystemService(Activity.java:3835)
06-06 10:06:22.434: E/AndroidRuntime(418):  at android.widget.ArrayAdapter.init(ArrayAdapter.java:314)
06-06 10:06:22.434: E/AndroidRuntime(418):  at android.widget.ArrayAdapter.<init>(ArrayAdapter.java:153)
06-06 10:06:22.434: E/AndroidRuntime(418):  at com.example.videosdcard.FileBrowser.getFiles(FileBrowser.java:71)
06-06 10:06:22.434: E/AndroidRuntime(418):  at com.example.videosdcard.FileBrowser.<init>(FileBrowser.java:37)
06-06 10:06:22.434: E/AndroidRuntime(418):  at com.example.videosdcard.VideoSDcard$1$1.onClick(VideoSDcard.java:240)
06-06 10:06:22.434: E/AndroidRuntime(418):  at com.android.internal.app.AlertController$ButtonHandler.handleMessage(AlertController.java:166)
06-06 10:06:22.434: E/AndroidRuntime(418):  at android.os.Handler.dispatchMessage(Handler.java:99)
06-06 10:06:22.434: E/AndroidRuntime(418):  at android.os.Looper.loop(Looper.java:126)
06-06 10:06:22.434: E/AndroidRuntime(418):  at android.app.ActivityThread.main(ActivityThread.java:3997)
06-06 10:06:22.434: E/AndroidRuntime(418):  at java.lang.reflect.Method.invokeNative(Native Method)
06-06 10:06:22.434: E/AndroidRuntime(418):  at java.lang.reflect.Method.invoke(Method.java:491)
06-06 10:06:22.434: E/AndroidRuntime(418):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:841)
06-06 10:06:22.434: E/AndroidRuntime(418):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599)
06-06 10:06:22.434: E/AndroidRuntime(418):  at dalvik.system.NativeStart.main(Native Method)
06-06 10:06:33.103: I/Process(418): Sending signal. PID: 418 SIG: 9

我正在从 URL 下载视频。并将其保存在 SD 卡上。我想浏览 sd 卡上的文件。所以我正在获取文件夹中存在的所有目录。这个我是可以做到的。

我想使用数组列表中的列表视图显示所有项目。

在这里,我使用 sd 卡中的数组列表获取所有项目。当我使用数组适配器填充列表视图时,这里会抛出错误。

错误如上所示。

我的代码是从父类派生的子类。我的意思是,第二类——FileBrowser

            /*Create Method to get all the Files and Folders from the current Directory we are in */

        getFiles(f.listFiles());
            System.out.println("List all Files:"+f.listFiles());
        }
        private void getFiles(File[] files) {
        items=new ArrayList<String>();
        System.out.println("Item files:"+items);
            for(File file : files){
                 System.out.println("Files:"+files);
                 items.add(file.getPath());
        }
            ArrayAdapter<String> adapter=new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, items);
            lv=(ListView)findViewById(R.id.main_LV_list);
            lv.setAdapter(adapter);
    }
}
4

3 回答 3

0

IllegalStateException:系统服务在 onCreate() 之前对活动不可用

而不是创建FileBrowser将适配器添加到 ListView 的构造函数,您将需要使用onCreate方法或onResume初始化 ListView 和访问系统服务。

@Override
protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main); //<< set layout here
   this.Context=context;
    f=new File(path);
    System.out.println("Full SD card path:"+f); 
    getFiles(f.listFiles());
    System.out.println("List all Files:"+f.listFiles());               

}

Environment.getExternalStorageDirectory()用于获取 SD-CARD 路径而不是静态字符串:

于 2013-06-06T05:52:52.153 回答
0

上下文在活动构造函数中不可用,它仅在 Activity.onCreate() 方法及其他方法中可用。

所以你必须使用活动的onCreate方法

于 2013-06-06T05:53:58.230 回答
-2

堆栈跟踪说明了您需要知道的所有内容:

java.lang.IllegalStateException:系统服务在 onCreate() 之前对活动不可用

于 2013-06-06T05:53:18.120 回答