Android--关于Cursor空指针的问题

在开发Android音乐播放器时,遇到Cursor空指针异常。原因是模拟器上缺少音乐文件,导致Cursor对象为空。解决方案是在使用Cursor之前检查其是否为空且是否有结果。

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

最近几天无聊自己动手写个音乐播放器,用到Cursor来取得数据库中音乐文件的

信息,但是当用到Cursor的时候总是报空指针错误,后来发现是模拟器上没有

音乐文件,使用Cursor的时候 ,若Cursor中没有结果,则Cursor的对象则为空

,所以在使用Cursor的时候最好先判断Cursor对象是否为空且其结果是否大于等于1,

以下是最开始的代码:

 

private void getSongMessage(){
		String TITLE = MediaStore.Audio.Media.TITLE;
		String DATA = MediaStore.Audio.Media.DATA;
		String ALBUM = MediaStore.Audio.Media.ALBUM;
		String ARTIST = MediaStore.Audio.Media.ARTIST;
		Uri uri = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI;
		ContentResolver cr = getContentResolver(); 
		Cursor cs = cr.query(uri, null, null, null, null);  

		while (cs.moveToNext()) {
			String title = cs.getString(cs.getColumnIndex(TITLE));
			String data = cs.getString(cs.getColumnIndex(DATA))
### 关于数据库游标的使用教程 在 Android 开发中,`Cursor` 是一种用于处理查询结果的核心对象[^2]。通过 `Cursor`,可以高效地缓冲查询数据而无需一次性加载所有数据到内存中。这种特性使得 `Cursor` 成为了操作 SQLite 数据库的理想工具。 #### 使用 Cursor 的基本流程 1. **执行查询并获取 Cursor 对象** 查询返回的结果会封装在一个 `Cursor` 对象中,该对象指向查询结果的第一行。如果查询无结果,则可以通过 `Cursor.getCount()` 方法判断其是否为空。 ```java SQLiteDatabase db = dbHelper.getReadableDatabase(); String[] projection = { "_id", "name", "age" }; Cursor cursor = db.query("users", projection, null, null, null, null, null); ``` 2. **遍历 Cursor 数据** 可以通过移动指针来访问每一行的数据。常用的方法包括 `moveToFirst()`, `moveToNext()`, 和 `isAfterLast()` 等。 ```java if (cursor != null && cursor.moveToFirst()) { do { int id = cursor.getInt(cursor.getColumnIndexOrThrow("_id")); String name = cursor.getString(cursor.getColumnIndexOrThrow("name")); int age = cursor.getInt(cursor.getColumnIndexOrThrow("age")); System.out.println("ID: " + id + ", Name: " + name + ", Age: " + age); } while (cursor.moveToNext()); } ``` 3. **关闭 Cursor 资源** 当完成对 `Cursor` 的操作后,务必调用 `close()` 方法释放资源,防止内存泄漏。 ```java if (cursor != null) { cursor.close(); } ``` #### 结合 ListView 显示数据 `SimpleCursorAdapter` 提供了一种简单的方式将 `Cursor` 中的数据绑定到 `ListView` 上显示[^1]。这种方式减少了手动解析和填充视图的工作量。 ```java String[] fromColumns = {"name", "age"}; int[] toViews = {R.id.text_name, R.id.text_age}; SimpleCursorAdapter adapter = new SimpleCursorAdapter(this, R.layout.list_item, cursor, fromColumns, toViews, 0); listView.setAdapter(adapter); ``` #### 加载器机制优化 Cursor 操作 为了避免主线程阻塞问题,推荐使用 `CursorLoader` 来异步加载数据[^3]。这不仅提升了用户体验,还简化了生命周期管理逻辑。 ```java public Loader<Cursor> onCreateLoader(int id, Bundle args) { return new CursorLoader( this, MyContentProvider.CONTENT_URI, PROJECTION, SELECTION, SELECTION_ARGS, SORT_ORDER ); } ``` --- ### 推荐学习资料 对于更深入的学习需求,建议查阅以下内容: - 官方文档:[Android Developers - Loaders](https://developer.android.com/guide/components/loaders) - 教程链接:[Android SQLite Database and ContentProvider - Tutorial][^2] ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值