强制关闭android Lollipop

时间:2015-10-30 07:11:40

标签: android android-5.0-lollipop forceclose

代码从sdcard / music获取音乐文件并查看主题列表

在android 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)

5 个答案:

答案 0 :(得分:0)

您是否已将以下权限添加到AndroidManifest.xml中?

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

列出目录中的文件需要外部存储读取访问权限。

答案 1 :(得分:0)

基于您的日志,其中包含:

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

我在你的代码中找到了这一行:

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

listFiles()方法返回一个空数组。它没有事件初始化或分配。因此,我想这条线上的一点保护会有助于这次崩溃:

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

此行将防止代码崩溃,但我不知道此行是否返回您需要的正确数组。当此路径下没有文件时,是否发生了此崩溃?

更新:thx @ JHH的建议

答案 2 :(得分:0)

你变量home为null。

  

获取此文件表示的目录中的文件列表。   然后通过FileFilter过滤此列表并匹配文件   作为一个文件数组返回。 如果此文件不是,则返回null   目录即可。如果filter为null,则所有文件都匹配。

见这里:Throwing null pointer exception in Android

我的第一个猜测是你没有任何权限。

答案 3 :(得分:0)

IMO,您应该尝试:put&#34; Music&#34;将文件夹放入手机存储空间(&#34;设备存储&#34;)。日志显示您的文件路径错误,因此listFiles()返回null

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

答案 4 :(得分:0)

全部谢谢

问题解决了

我改变了

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

home.listFiles(new FileExtensionFilter()).length != 0