2015-10-30 5 views
0

в коде Получить музыкальные файлы из SDCard/музыки и просмотра списка темысила близко от андроида леденца

в андроиде 5 силы близко происходят

Я думаю, что проблема эта функция

FileExtensionFilter()

package com.ghs.musicsatsametime; 

import java.io.File; 
import java.io.FilenameFilter; 
import java.util.ArrayList; 
import java.util.HashMap; 

public class SongsManager { 
    // SDCard Path 
    final String MEDIA_PATH = new String("/sdcard/Music"); 
    private ArrayList<HashMap<String, String>> songsList = new ArrayList<HashMap<String, String>>(); 

    // Constructor 
    public SongsManager(){ 

    } 

    /** 
    * Function to read all mp3 files from sdcard 
    * and store the details in ArrayList 
    * */ 
    public ArrayList<HashMap<String, String>> getPlayList(){ 
     File home = new File(MEDIA_PATH); 

     if (home.listFiles(new FileExtensionFilter()).length > 0) { 
      for (File file : home.listFiles(new FileExtensionFilter())) { 
       HashMap<String, String> song = new HashMap<String, String>(); 
       song.put("songTitle", file.getName().substring(0, (file.getName().length() - 4))); 
       song.put("songPath", file.getPath()); 

       // Adding each song to SongList 
       songsList.add(song); 
      } 
     } 
     // return songs list array 
     return songsList; 
    } 

    /** 
    * Class to filter files which are having .mp3 extension 
    * */ 
    class FileExtensionFilter implements FilenameFilter { 
     public boolean accept(File dir, String name) { 
      return (name.endsWith(".mp3") || name.endsWith(".MP3")); 
     } 
    } 
} 

и мой LogCat

10-30 10:45:30.176: E/AndroidRuntime(15788): FATAL EXCEPTION: main 
10-30 10:45:30.176: E/AndroidRuntime(15788): Process: com.ghs.musicsatsametime, PID: 15788 
10-30 10:45:30.176: E/AndroidRuntime(15788): java.lang.NullPointerException: Attempt to get length of null array 
10-30 10:45:30.176: E/AndroidRuntime(15788): at com.ghs.musicsatsametime.SongsManager.getPlayList(SongsManager.java:25) 
10-30 10:45:30.176: E/AndroidRuntime(15788): at com.ghs.musicsatsametime.dj.DJMusicFragment.getMusicList(DJMusicFragment.java:421) 
10-30 10:45:30.176: E/AndroidRuntime(15788): at com.ghs.musicsatsametime.dj.DJMusicFragment.access$22(DJMusicFragment.java:415) 
10-30 10:45:30.176: E/AndroidRuntime(15788): at com.ghs.musicsatsametime.dj.DJMusicFragment$7.onClick(DJMusicFragment.java:359) 
10-30 10:45:30.176: E/AndroidRuntime(15788): at android.view.View.performClick(View.java:4856) 
10-30 10:45:30.176: E/AndroidRuntime(15788): at android.view.View$PerformClick.run(View.java:19956) 
10-30 10:45:30.176: E/AndroidRuntime(15788): at android.os.Handler.handleCallback(Handler.java:739) 
10-30 10:45:30.176: E/AndroidRuntime(15788): at android.os.Handler.dispatchMessage(Handler.java:95) 
10-30 10:45:30.176: E/AndroidRuntime(15788): at android.os.Looper.loop(Looper.java:211) 
10-30 10:45:30.176: E/AndroidRuntime(15788): at android.app.ActivityThread.main(ActivityThread.java:5371) 
10-30 10:45:30.176: E/AndroidRuntime(15788): at java.lang.reflect.Method.invoke(Native Method) 
10-30 10:45:30.176: E/AndroidRuntime(15788): at java.lang.reflect.Method.invoke(Method.java:372) 
10-30 10:45:30.176: E/AndroidRuntime(15788): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:945) 
10-30 10:45:30.176: E/AndroidRuntime(15788): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:740) 
+0

Отправьте свой логарифм, пожалуйста. – yennsarah

+0

Исключение StackTrace было бы полезно – Neil

+0

Попытка получить длину нулевого массива - ошибка. – RvdK

ответ

0

Вы добавили следующие разрешения на свой AndroidManifest.xml?

<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> 

Для доступа к файлам в каталоге требуется доступ для чтения с внешнего хранилища.

0

Основываясь на входе, который говорит:

java.lang.NullPointerException: Attempt to get length of null array 

Я нашел эту строку в коде:

if (home.listFiles(new FileExtensionFilter()).length > 0) { 

The listFiles() метод возвращает нулевой массив. Это не событие init или выделено. Таким образом, я думаю, немного защиты от этой линии будет способствовать эту аварии:

List<File> files = home.listFiles(new FileExtensionFilter()); 
if (null != files && files.length > 0) { 
    for(File file:files){ 
     ... 
    } 
} 

этой линии будет pretect кода от падения, но я не знаю, возвращает ли эта строка правильного массив вам нужно. Этот сбой произошел, когда нет файла под этим путем?

обновление: предложение THx @ JHH в

+0

И ответ Нила также очень важная часть должна быть проверена. –

+0

Не очень эффективно запускать код дважды и создавать объекты * two * filter. В этом случае, объявляя и присваивая локальную переменную значение 'listFiles()', *, затем * проверка нулевой отметки и проверка длины, было бы лучше. – JHH

+0

Thx @JHH ~ u r справа. –

0

Вы переменная дом пустой.

Получает список файлов в каталоге, представленном этим файлом. Этот список затем фильтруется через FileFilter, и соответствующие файлы: , возвращаемые в виде массива файлов. Возвращает null, если этот файл не является directory. Если фильтр равен нулю, все файлы совпадают.

Смотрите здесь: Throwing null pointer exception in Android

Моя первая догадка у вас нет каких-либо разрешений.

0

IMO, вы должны попробовать: поместите папку «Музыка» в хранилище телефона («Хранилище устройств»).Журнал показал, что ваш путь к файлу является неправильным, так listFiles() возвращают нуль

final String MEDIA_PATH = Environment.getExternalStorageDirectory() + "/Music/"); 
0

Спасибо всем

проблема решена

Я изменил

home.listFiles(new FileExtensionFilter()).length > 0 

в

home.listFiles(new FileExtensionFilter()).length != 0 
Смежные вопросы