【发布时间】:2014-06-19 07:43:15
【问题描述】:
我的片段包含ListView。对于这个ListView,我制作了一个自定义list item layout 和一个自定义ListAdapter。
private DSongListAdapter adapter;
private ArrayList<Song> songList;
private View rootView;
private ListView listView;
@Override
public View onCreateView( LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState ){
rootView = inflater.inflate(R.layout.fragment_song, container, false);
listView = (ListView) rootView.findViewById( R.id.playlist_listview );
songList = new ArrayList<Song>();
adapter = new DSongListAdapter(getActivity(), songList);
listView.setAdapter(adapter); //Crashes now!
return rootView;
}
我的适配器类:
public class DSongListAdapter extends ArrayAdapter<Song> {
Context mContext;
List<Song> mObjects;
public DSongListAdapter(Context context, List<Song> songList ) {
super(context, R.layout.list_item, songList );
this.mContext = context;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View itemView = convertView;
if( itemView != null ){
itemView = ((Activity) mContext).getLayoutInflater().inflate(R.layout.list_item, parent, false);
TextView titleLabel = (TextView) itemView.findViewById(R.id.titleLabel);
if( titleLabel != null )
titleLabel.setText( mObjects.get(position).getTitle() );
}
return convertView;
}
}
但是,当我设置适配器时它崩溃了!我得到一个空指针异常错误。
06-19 09:39:48.662:E/AndroidRuntime(29153):致命异常:主要 06-19 09:39:48.662: E/AndroidRuntime(29153): java.lang.NullPointerException 06-19 09:39:48.662: E/AndroidRuntime(29153):在 com.davlog.musicplayer.SongFragment.onCreateView(SongFragment.java:31) 06-19 09:39:48.662: E/AndroidRuntime(29153): 在 android.app.Fragment.performCreateView(Fragment.java:1699) 06-19 09:39:48.662:E/AndroidRuntime(29153):在 android.app.FragmentManagerImpl.moveToState(FragmentManager.java:903) 06-19 09:39:48.662: E/AndroidRuntime(29153): 在 android.app.FragmentManagerImpl.moveToState(FragmentManager.java:1075) 06-19 09:39:48.662: E/AndroidRuntime(29153): 在 android.app.BackStackRecord.run(BackStackRecord.java:682) 06-19 09:39:48.662:E/AndroidRuntime(29153):在 android.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1455) 06-19 09:39:48.662: E/AndroidRuntime(29153): 在 android.app.FragmentManagerImpl$1.run(FragmentManager.java:441) 06-19 09:39:48.662:E/AndroidRuntime(29153):在 android.os.Handler.handleCallback(Handler.java:725) 06-19 09:39:48.662:E/AndroidRuntime(29153):在 android.os.Handler.dispatchMessage(Handler.java:92) 06-19 09:39:48.662:E/AndroidRuntime(29153):在 android.os.Looper.loop(Looper.java:137) 06-19 09:39:48.662: E/AndroidRuntime(29153):在 android.app.ActivityThread.main(ActivityThread.java:5306) 06-19 09:39:48.662:E/AndroidRuntime(29153):在 java.lang.reflect.Method.invokeNative(Native Method) 06-19 09:39:48.662:E/AndroidRuntime(29153):在 java.lang.reflect.Method.invoke(Method.java:511) 06-19 09:39:48.662: E/AndroidRuntime(29153):在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102) 06-19 09:39:48.662: E/AndroidRuntime(29153): 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869) 06-19 09:39:48.662:E/AndroidRuntime(29153):在 dalvik.system.NativeStart.main(Native Method)
【问题讨论】:
-
那么日志猫错误呢?
-
@Prince 我的 onCreateView 中出现 NullPointerException
-
你能用问题分享日志错误吗?
-
@Prince 我发布了错误。
-
所以
fragment_song布局没有playlist_listview。