UriMatcher 클래스

정의

콘텐츠 공급자에서 URI를 일치시키는 데 도움이 되는 유틸리티 클래스입니다.

[Android.Runtime.Register("android/content/UriMatcher", DoNotGenerateAcw=true)]
public class UriMatcher : Java.Lang.Object
[<Android.Runtime.Register("android/content/UriMatcher", DoNotGenerateAcw=true)>]
type UriMatcher = class
    inherit Object
상속
UriMatcher
특성

설명

콘텐츠 공급자에서 URI를 일치시키는 데 도움이 되는 유틸리티 클래스입니다.

이 클래스를 사용하려면 개체 트리 UriMatcher 를 빌드합니다. 예를 들면 다음과 같습니다.

private static final int PEOPLE = 1;
                private static final int PEOPLE_ID = 2;
                private static final int PEOPLE_PHONES = 3;
                private static final int PEOPLE_PHONES_ID = 4;
                private static final int PEOPLE_CONTACTMETHODS = 7;
                private static final int PEOPLE_CONTACTMETHODS_ID = 8;

                private static final int DELETED_PEOPLE = 20;

                private static final int PHONES = 9;
                private static final int PHONES_ID = 10;
                private static final int PHONES_FILTER = 14;

                private static final int CONTACTMETHODS = 18;
                private static final int CONTACTMETHODS_ID = 19;

                private static final int CALLS = 11;
                private static final int CALLS_ID = 12;
                private static final int CALLS_FILTER = 15;

                private static final UriMatcher sURIMatcher = new UriMatcher(UriMatcher.NO_MATCH);

                static
                {
                    sURIMatcher.addURI("contacts", "people", PEOPLE);
                    sURIMatcher.addURI("contacts", "people/#", PEOPLE_ID);
                    sURIMatcher.addURI("contacts", "people/#/phones", PEOPLE_PHONES);
                    sURIMatcher.addURI("contacts", "people/#/phones/#", PEOPLE_PHONES_ID);
                    sURIMatcher.addURI("contacts", "people/#/contact_methods", PEOPLE_CONTACTMETHODS);
                    sURIMatcher.addURI("contacts", "people/#/contact_methods/#", PEOPLE_CONTACTMETHODS_ID);
                    sURIMatcher.addURI("contacts", "deleted_people", DELETED_PEOPLE);
                    sURIMatcher.addURI("contacts", "phones", PHONES);
                    sURIMatcher.addURI("contacts", "phones/filter/*", PHONES_FILTER);
                    sURIMatcher.addURI("contacts", "phones/#", PHONES_ID);
                    sURIMatcher.addURI("contacts", "contact_methods", CONTACTMETHODS);
                    sURIMatcher.addURI("contacts", "contact_methods/#", CONTACTMETHODS_ID);
                    sURIMatcher.addURI("call_log", "calls", CALLS);
                    sURIMatcher.addURI("call_log", "calls/filter/*", CALLS_FILTER);
                    sURIMatcher.addURI("call_log", "calls/#", CALLS_ID);
                }

API 수준에서 android.os.Build.VERSION_CODES#JELLY_BEAN_MR2시작하여 경로는 선행 슬래시로 시작할 수 있습니다. 예를 들면 다음과 같습니다.

sURIMatcher.addURI("contacts", "/people", PEOPLE);

그런 다음, URI와 일치해야 하는 경우 를 호출 #match하여 지정된 URL을 제공합니다. 그렇지 않으면 필요한 if-else 논리를 모두 복제하지 않고 결과를 사용하여 쿼리를 빌드하고, 형식을 반환하고, 행을 삽입하거나 삭제하거나, 필요한 모든 항목을 삭제할 수 있습니다. 예를 들면 다음과 같습니다.

public String getType(Uri url)
                {
                    int match = sURIMatcher.match(url);
                    switch (match)
                    {
                        case PEOPLE:
                            return "vnd.android.cursor.dir/person";
                        case PEOPLE_ID:
                            return "vnd.android.cursor.item/person";
            ... snip ...
                            return "vnd.android.cursor.dir/snail-mail";
                        case PEOPLE_ADDRESS_ID:
                            return "vnd.android.cursor.item/snail-mail";
                        default:
                            return null;
                    }
                }

위의 선언을 아래의 선언 대신 사용할 수 있습니다.

public String getType(Uri url)
                {
                    List<String> pathSegments = url.getPathSegments();
                    if (pathSegments.size() >= 2) {
                        if ("people".equals(pathSegments.get(1))) {
                            if (pathSegments.size() == 2) {
                                return "vnd.android.cursor.dir/person";
                            } else if (pathSegments.size() == 3) {
                                return "vnd.android.cursor.item/person";
            ... snip ...
                                return "vnd.android.cursor.dir/snail-mail";
                            } else if (pathSegments.size() == 3) {
                                return "vnd.android.cursor.item/snail-mail";
                            }
                        }
                    }
                    return null;
                }

에 대한 Java 설명서입니다 android.content.UriMatcher.

이 페이지의 일부는 만들고 공유하며 에 설명된 용어에 따라 사용되는 작업을 기반으로 수정됩니다.

생성자

UriMatcher(Int32)

URI 트리의 루트 노드를 만듭니다.

UriMatcher(IntPtr, JniHandleOwnership)

JNI 개체의 관리되는 표현을 만들 때 사용되는 생성자입니다. 런타임에서 호출합니다.

필드

NoMatch

속성

Class

Object의 런타임 클래스를 반환합니다.

(다음에서 상속됨 Object)
Handle

기본 Android instance 대한 핸들입니다.

(다음에서 상속됨 Object)
JniIdentityHashCode

콘텐츠 공급자에서 URI를 일치시키는 데 도움이 되는 유틸리티 클래스입니다.

(다음에서 상속됨 Object)
JniPeerMembers

콘텐츠 공급자에서 URI를 일치시키는 데 도움이 되는 유틸리티 클래스입니다.

PeerReference

콘텐츠 공급자에서 URI를 일치시키는 데 도움이 되는 유틸리티 클래스입니다.

(다음에서 상속됨 Object)
ThresholdClass

이 API는 Android용 Mono 인프라를 지원하며 코드에서 직접 사용할 수 없습니다.

ThresholdType

이 API는 Android용 Mono 인프라를 지원하며 코드에서 직접 사용할 수 없습니다.

메서드

AddURI(String, String, Int32)

일치시킬 URI와 이 URI가 일치할 때 반환할 코드를 추가합니다.

Clone()

이 개체의 복사본을 만들고 반환합니다.

(다음에서 상속됨 Object)
Dispose()

콘텐츠 공급자에서 URI를 일치시키는 데 도움이 되는 유틸리티 클래스입니다.

(다음에서 상속됨 Object)
Dispose(Boolean)

콘텐츠 공급자에서 URI를 일치시키는 데 도움이 되는 유틸리티 클래스입니다.

(다음에서 상속됨 Object)
Equals(Object)

다른 개체가 이 개체와 "같음"인지 여부를 나타냅니다.

(다음에서 상속됨 Object)
GetHashCode()

개체의 해시 코드 값을 반환합니다.

(다음에서 상속됨 Object)
JavaFinalize()

가비지 수집에서 개체에 대한 참조가 더 이상 없다고 판단할 때 개체의 가비지 수집기에서 호출됩니다.

(다음에서 상속됨 Object)
Match(Uri)

URL의 경로와 일치시키려고 합니다.

Notify()

이 개체의 모니터에서 대기 중인 단일 스레드를 해제합니다.

(다음에서 상속됨 Object)
NotifyAll()

이 개체의 모니터에서 대기 중인 모든 스레드를 해제합니다.

(다음에서 상속됨 Object)
SetHandle(IntPtr, JniHandleOwnership)

Handle 속성을 설정합니다.

(다음에서 상속됨 Object)
ToArray<T>()

콘텐츠 공급자에서 URI를 일치시키는 데 도움이 되는 유틸리티 클래스입니다.

(다음에서 상속됨 Object)
ToString()

개체의 문자열 표현을 반환합니다.

(다음에서 상속됨 Object)
UnregisterFromRuntime()

콘텐츠 공급자에서 URI를 일치시키는 데 도움이 되는 유틸리티 클래스입니다.

(다음에서 상속됨 Object)
Wait()

현재 스레드가 각성될 때까지 대기하도록 합니다. 일반적으로 <알림을<> 받>거나<<> 중단/em>합니다.

(다음에서 상속됨 Object)
Wait(Int64)

현재 스레드가 깨어날 때까지 대기하게 하며, 일반적으로 <알림을 받<>거나 중단</>em>>을 받거나 <일정량의 실시간이 경과할 때까지 대기합니다.

(다음에서 상속됨 Object)
Wait(Int64, Int32)

현재 스레드가 깨어날 때까지 대기하게 하며, 일반적으로 <알림을 받<>거나 중단</>em>>을 받거나 <일정량의 실시간이 경과할 때까지 대기합니다.

(다음에서 상속됨 Object)

명시적 인터페이스 구현

IJavaPeerable.Disposed()

콘텐츠 공급자에서 URI를 일치시키는 데 도움이 되는 유틸리티 클래스입니다.

(다음에서 상속됨 Object)
IJavaPeerable.DisposeUnlessReferenced()

콘텐츠 공급자에서 URI를 일치시키는 데 도움이 되는 유틸리티 클래스입니다.

(다음에서 상속됨 Object)
IJavaPeerable.Finalized()

콘텐츠 공급자에서 URI를 일치시키는 데 도움이 되는 유틸리티 클래스입니다.

(다음에서 상속됨 Object)
IJavaPeerable.JniManagedPeerState

콘텐츠 공급자에서 URI를 일치시키는 데 도움이 되는 유틸리티 클래스입니다.

(다음에서 상속됨 Object)
IJavaPeerable.SetJniIdentityHashCode(Int32)

콘텐츠 공급자에서 URI를 일치시키는 데 도움이 되는 유틸리티 클래스입니다.

(다음에서 상속됨 Object)
IJavaPeerable.SetJniManagedPeerState(JniManagedPeerStates)

콘텐츠 공급자에서 URI를 일치시키는 데 도움이 되는 유틸리티 클래스입니다.

(다음에서 상속됨 Object)
IJavaPeerable.SetPeerReference(JniObjectReference)

콘텐츠 공급자에서 URI를 일치시키는 데 도움이 되는 유틸리티 클래스입니다.

(다음에서 상속됨 Object)

확장 메서드

JavaCast<TResult>(IJavaObject)

Android 런타임 확인 형식 변환을 수행합니다.

JavaCast<TResult>(IJavaObject)

콘텐츠 공급자에서 URI를 일치시키는 데 도움이 되는 유틸리티 클래스입니다.

GetJniTypeName(IJavaPeerable)

콘텐츠 공급자에서 URI를 일치시키는 데 도움이 되는 유틸리티 클래스입니다.

적용 대상