UriMatcher 是一个方便的类,当您编写 ContentProvider 或其他需要响应多个不同 URI 的类时。在您的示例中,用户可以使用 URI 查询您的提供商,例如:
myprovider://cte
或
myprovider://cte/somestring
构造 UriMatcher 时,需要为每个 URI 设置单独的代码(而不仅仅是示例中的“uriCode”)。我通常使我的UriMatcher实例成为静态的,并将URI添加到静态构造函数中:
private static final int CTE_ALL = 1;
private static final int CTE_FIND = 2;
private static final UriMatcher uriMatcher = new UriMatcher(UriMatcher.NO_MATCH);
static {
uriMatcher.addURI(PROVIDER_NAME, "cte", CTE_ALL);
uriMatcher.addURI(PROVIDER_NAME, "cte/*", CTE_FIND);
}
然后在 ContentProvider 中,您可以在查询方法中执行如下操作:
Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) {
int res = uriMatcher.match(uri);
switch (res) {
case CTE_ALL:
//TODO create a results Cursor with all the CTE results
break;
case CTE_FIND:
//TODO create a results Cursor with the single CTE requested
break;
}
return results;
}