Android日历-查询实例表不总是返回最新数据
创始人
2024-10-09 18:32:01
0

在Android日历中,查询实例表不总是返回最新数据的问题可能是由于缓存数据或异步查询导致的。以下是解决该问题的代码示例:

方法1:使用AsyncQueryHandler进行异步查询

public class MainActivity extends AppCompatActivity {

    private static final int QUERY_INSTANCE_TOKEN = 1;

    private AsyncQueryHandler queryHandler;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        queryHandler = new MyAsyncQueryHandler(getContentResolver());

        // 查询实例表
        Uri uri = CalendarContract.Instances.CONTENT_URI;
        String[] projection = {CalendarContract.Instances.TITLE, CalendarContract.Instances.BEGIN, CalendarContract.Instances.END};
        String selection = null;
        String[] selectionArgs = null;
        String sortOrder = null;

        queryHandler.startQuery(QUERY_INSTANCE_TOKEN, null, uri, projection, selection, selectionArgs, sortOrder);
    }

    private class MyAsyncQueryHandler extends AsyncQueryHandler {

        public MyAsyncQueryHandler(ContentResolver cr) {
            super(cr);
        }

        @Override
        protected void onQueryComplete(int token, Object cookie, Cursor cursor) {
            super.onQueryComplete(token, cookie, cursor);

            if (token == QUERY_INSTANCE_TOKEN) {
                // 处理查询结果
                if (cursor != null && cursor.moveToFirst()) {
                    do {
                        // 获取数据
                        String title = cursor.getString(cursor.getColumnIndex(CalendarContract.Instances.TITLE));
                        long beginTime = cursor.getLong(cursor.getColumnIndex(CalendarContract.Instances.BEGIN));
                        long endTime = cursor.getLong(cursor.getColumnIndex(CalendarContract.Instances.END));

                        // 处理数据...
                    } while (cursor.moveToNext());
                }
                // 关闭游标
                if (cursor != null) {
                    cursor.close();
                }
            }
        }
    }
}

方法2:使用ContentObserver监听数据变化

public class MainActivity extends AppCompatActivity {

    private static final int QUERY_INSTANCE_TOKEN = 1;

    private Cursor cursor;
    private ContentObserver contentObserver;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        // 注册ContentObserver
        contentObserver = new MyContentObserver();
        getContentResolver().registerContentObserver(CalendarContract.Instances.CONTENT_URI, true, contentObserver);

        // 查询实例表
        Uri uri = CalendarContract.Instances.CONTENT_URI;
        String[] projection = {CalendarContract.Instances.TITLE, CalendarContract.Instances.BEGIN, CalendarContract.Instances.END};
        String selection = null;
        String[] selectionArgs = null;
        String sortOrder = null;

        cursor = getContentResolver().query(uri, projection, selection, selectionArgs, sortOrder);
        if (cursor != null && cursor.moveToFirst()) {
            do {
                // 获取数据
                String title = cursor.getString(cursor.getColumnIndex(CalendarContract.Instances.TITLE));
                long beginTime = cursor.getLong(cursor.getColumnIndex(CalendarContract.Instances.BEGIN));
                long endTime = cursor.getLong(cursor.getColumnIndex(CalendarContract.Instances.END));

                // 处理数据...
            } while (cursor.moveToNext());
        }
    }

    @Override
    protected void onDestroy() {
        super.onDestroy();
        // 取消注册ContentObserver
        getContentResolver().unregisterContentObserver(contentObserver);

        // 关闭游标
        if (cursor != null) {
            cursor.close();
        }
    }

    private class MyContentObserver extends ContentObserver {

        public MyContentObserver() {
            super(new Handler());
        }

        @Override
        public void onChange(boolean selfChange) {
            super.onChange(selfChange);

            // 查询实例表
            Uri uri = CalendarContract.Instances.CONTENT_URI;
            String[] projection = {CalendarContract.Instances.TITLE, CalendarContract.Instances.BEGIN, CalendarContract.Instances.END};
            String selection = null;
            String[] selectionArgs = null;
            String sortOrder = null;

            Cursor newCursor = getContentResolver().query(uri, projection, selection, selectionArgs, sortOrder);
            if (newCursor != null && newCursor.moveToFirst()) {
                do {
                    // 获取数据
                    String title = newCursor.getString(newCursor.getColumnIndex(CalendarContract.Instances.TITLE));
                    long beginTime = newCursor.getLong(newCursor.getColumnIndex(CalendarContract.Instances.BEGIN));
                    long endTime = newCursor.getLong(newCursor.getColumnIndex(CalendarContract.Instances.END));

                    // 处理数据...
                } while (newCursor.moveToNext());
            }

            // 关闭新游标
            if (newCursor != null) {
                newCursor.close();
            }
        }
    }
}

这些代码示例演示了两种解决方法:使用AsyncQueryHandler进行异步查询和使用

相关内容

热门资讯

黑科技好友房!红龙扑克透牌规则... 黑科技好友房!红龙扑克透牌规则,智星德州菠萝app下载,其实是真的有挂(2025已更新)-哔哩哔哩是...
黑科技计算!红龙扑克辅助器,德... 黑科技计算!红龙扑克辅助器,德扑之星隐藏功能,原来是真的有挂(2020已更新)-哔哩哔哩这是由厦门游...
黑科技计算!智星德州菠萝外挂,... 黑科技计算!智星德州菠萝外挂,德扑之星怎么清楚数据,最初存在有挂(2023已更新)-哔哩哔哩;智星德...
黑科技辅助挂!智星德州辅助器,... 黑科技辅助挂!智星德州辅助器,德扑之星怎么让系统给好牌,切实真的有挂(2023已更新)-哔哩哔哩;(...
黑科技中牌率!智星德州菠萝辅助... 黑科技中牌率!智星德州菠萝辅助器推荐,德扑之星怎么设置埋牌,都是存在有挂(2021已更新)-哔哩哔哩...
黑科技系统!红龙扑克透牌辅助器... 黑科技系统!红龙扑克透牌辅助器,德扑之星的机制,果然是有挂(2020已更新)-哔哩哔哩;建议优先通过...
黑科技规律!红龙扑克发牌有问题... 黑科技规律!红龙扑克发牌有问题,德扑分析软件,往昔是真的有挂(2020已更新)-哔哩哔哩;是一款可以...
黑科技挂!智星德州菠萝有辅助器... 智星德州菠萝有辅助器吗赢率提升策略‌;黑科技挂!智星德州菠萝有辅助器吗,德扑之星隐藏功能在哪,最初有...
黑科技玄学!红龙扑克发牌有问题... 黑科技玄学!红龙扑克发牌有问题,德扑之星数据解析,原生是真的有挂(2024已更新)-哔哩哔哩1、玩家...
黑科技了解!智星德州菠萝辅助器... 黑科技了解!智星德州菠萝辅助器免费下载,聚星扑克辅助软件,原来是有挂(2025已更新)-哔哩哔哩,支...