android之List<T>的空指针问题_List的初始化

本文通过一个具体的例子,讲述了如何避免在Android开发中因List未正确初始化而导致的空指针异常,并介绍了不同类型的List及其使用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在使用list做东西的时候出现空指针,查了半天资料

本来是这样的

	List<Restaurant> model;
	LunchListAdapter adapter;//这是我重写的适配器
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		adapter = new LunchListAdapter(LunchList.this, R.layout.row, model);
		model = new ArrayList<Restaurant>();		
		.....//省略}	

重点在倒数两行,本来我把List的初始化放在了onCreate里面,心想应该没有问题的,activity启动之后就会对它初始化了,后来我尝试着在第一行就初始化,结果就不报空指针异常,

后来发现,在初始化之前竟然把他当参数传了出去,结果就导致了空指针异常.

修改如下,初始化在前,使用在后:

 List<Restaurant> model;
	LunchListAdapter adapter;//这是我重写的适配器
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
                  model = new ArrayList<Restaurant>();
		adapter = new LunchListAdapter(LunchList.this, R.layout.row, model);
				
		.....//省略}


虽然很简单,但还是要总结一下的,空指针害人太深.

对于List的初始化还是有些讲究的.

List是一个接口,这个一看文档便知,所以对它初始化不能new List,而应该使用ArrayList或者LinkList(这些实例化了List接口),

List<T> list = new ArrayList<T>();

而且,如果你确定List里面存放的数据类型,可以直接初始化为这种List,

List<String> list = new LinkedList<String>();

这样能够快速的处理,存取数据就不用再进行类型转换,直接是String就行了,

如果在初始化时是这样的,

List<Object> list = new LinkedList<Object>();

那么在存储时就能存储各种类型的数据了,int,String,Map,甚至是你自己定义的class都可以.

当然这样在存取时候是要进行类型转换的,效率会低一些.

 

还有,关于空指针错误真的是很困扰人的一件事情,所以最好的解决方式就是在使用前 一定要保证完成正确的初始化.

// 优化后的 FilterableAdapter 类 public static abstract class FilterableAdapter<T> extends ArrayAdapter<T> implements Filterable { private static final String TAG = "FilterableAdapter"; private final LayoutInflater inflater; private List<T> originalList; private List<T> filteredList; private final ItemFilter filter = new ItemFilter(); public FilterableAdapter(Context context, int resource, List<T> objects) { super(context, resource, objects); this.inflater = LayoutInflater.from(context); this.originalList = new ArrayList<>(objects); this.filteredList = new ArrayList<>(objects); } @Override public int getCount() { return filteredList.size(); } @Override public T getItem(int position) { return filteredList.get(position); } // 核心优化:统一的格式化方法 protected abstract String formatItemText(T item); @NonNull @Override public View getView(int position, @Nullable View convertView, @NonNull ViewGroup parent) { if (convertView == null) { convertView = inflater.inflate(android.R.layout.simple_dropdown_item_1line, parent, false); } TextView textView = convertView.findViewById(android.R.id.text1); T item = getItem(position); textView.setText(item != null ? formatItemText(item) : ""); return convertView; } @Override public View getDropDownView(int position, @Nullable View convertView, @NonNull ViewGroup parent) { if (convertView == null) { convertView = inflater.inflate(android.R.layout.simple_dropdown_item_1line, parent, false); } TextView textView = convertView.findViewById(android.R.id.text1); T item = getItem(position); textView.setText(item != null ? formatItemText(item) : ""); return convertView; } public void updateList(List<T> newList) { this.originalList = new ArrayList<>(newList); this.filteredList = new ArrayList<>(newList); notifyDataSetChanged(); } @Override public Filter getFilter() { return filter; } private class ItemFilter extends Filter { @Override protected FilterResults performFiltering(CharSequence constraint) { FilterResults results = new FilterResults(); List<T> filtered = new ArrayList<>(); if (constraint == null || constraint.length() == 0) { filtered.addAll(originalList); } else { String filterPattern = constraint.toString().toLowerCase().trim(); for (T item : originalList) { if (formatItemText(item).toLowerCase().contains(filterPattern)) { filtered.add(item); } } } results.values = filtered; results.count = filtered.size(); return results; } @Override @SuppressWarnings("unchecked") protected void publishResults(CharSequence constraint, FilterResults results) { filteredList = (List<T>) results.values; if (results.count > 0 || constraint == null || constraint.length() == 0) { notifyDataSetChanged(); } else { notifyDataSetInvalidated(); } } } } 选择之后显示的还是内存地址
07-01
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值