Hashtable 클래스
정의
중요
일부 정보는 릴리스되기 전에 상당 부분 수정될 수 있는 시험판 제품과 관련이 있습니다. Microsoft는 여기에 제공된 정보에 대해 어떠한 명시적이거나 묵시적인 보증도 하지 않습니다.
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다.
[Android.Runtime.Register("java/util/Hashtable", DoNotGenerateAcw=true)]
[Java.Interop.JavaTypeParameters(new System.String[] { "K", "V" })]
public class Hashtable : Java.Util.Dictionary, IDisposable, Java.Interop.IJavaPeerable, Java.IO.ISerializable, Java.Lang.ICloneable, Java.Util.IMap
[<Android.Runtime.Register("java/util/Hashtable", DoNotGenerateAcw=true)>]
[<Java.Interop.JavaTypeParameters(new System.String[] { "K", "V" })>]
type Hashtable = class
inherit Dictionary
interface ISerializable
interface IJavaObject
interface IDisposable
interface IJavaPeerable
interface ICloneable
interface IMap
- 상속
- 특성
- 구현
설명
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. 비-null
개체는 키 또는 값으로 사용할 수 있습니다.
해시 테이블의 개체를 성공적으로 저장하고 검색하려면 키로 사용되는 개체가 메서드와 메서드를 hashCode
equals
구현해야 합니다.
인스턴스에는 성능에 Hashtable
영향을 주는 두 개의 매개 변수인 초기 용량 및 로드 팩터가 있습니다. 용량은 해시 테이블의 버킷 수이며, 초기 용량은 해시 테이블을 만들 때의 용량일 뿐입니다. 해시 테이블은 열려 있습니다. "해시 충돌"의 경우 단일 버킷은 순차적으로 검색해야 하는 여러 항목을 저장합니다. 부하 계수는 해시 테이블의 용량이 자동으로 증가하기 전에 가져올 수 있는 전체 용량의 측정값입니다. 초기 용량 및 로드 팩터 매개 변수는 구현에 대한 힌트일 뿐입니다. rehash 메서드가 호출되는 시기 및 여부에 대한 정확한 세부 정보는 구현에 따라 다릅니다.
일반적으로 기본 로드 팩터(.75)는 시간과 공간 비용 간에 적절한 절충을 제공합니다. 값이 높을수록 공간 오버헤드가 줄어들지만 항목을 조회하는 데 드는 시간 비용이 증가합니다get
(포함 및 put
등 대부분의 Hashtable
작업에 반영됨).
초기 용량은 낭비되는 공간과 시간이 많이 걸리는 작업의 필요성 rehash
간의 절충을 제어합니다. 초기 용량이 포함할최대 항목 Hashtable
수보다 큰 경우 로드 인수로 나눈 작업은 발생하지 않습니다rehash
. 그러나 초기 용량을 너무 높게 설정하면 공간이 낭비될 수 있습니다.
많은 항목을 만들려면 Hashtable
용량이 충분히 큰 항목을 만들면 테이블을 증가시키는 데 필요한 경우 자동 다시 해시를 수행하는 것보다 항목을 더 효율적으로 삽입할 수 있습니다.
이 예제에서는 숫자의 해시 테이블을 만듭니다. 숫자의 이름을 키로 사용합니다.
{@code
Hashtable<String, Integer> numbers
= new Hashtable<String, Integer>();
numbers.put("one", 1);
numbers.put("two", 2);
numbers.put("three", 3);}
숫자를 검색하려면 다음 코드를 사용합니다.
{@code
Integer n = numbers.get("two");
if (n != null) {
System.out.println("two = " + n);
}}
이 클래스의 모든 "컬렉션 뷰 메서드"<에서 반환된 컬렉션의 메서드에서 반환 iterator
되는 반복기는 em>fail-fast</em>입니다. 반복기가 생성된 후 언제든지 Hashtable이 구조적으로 수정되는 경우 반복기의 메서드를 remove
제외한 모든 방식으로 반복기가 throwConcurrentModificationException
됩니다. 따라서 동시 수정 시 반복기는 나중에 결정되지 않은 시간에 임의적이고 비결정적인 동작의 위험을 감수하지 않고 신속하고 깔끔하게 실패합니다. Hashtable #keys keys
및 #elements elements
메서드에서 반환된 열거형은 <>장애 조치(>fail-fast)가 아닙니다<. 열거형이 생성된 후 언제든지 Hashtable이 구조적으로 수정되면 열거 결과가 정의되지 않습니다.
일반적으로 비동기화된 동시 수정이 있는 상태에서는 반복기의 빠른 장애 조치(fail-fast) 동작을 보장할 수 없습니다. 장애 조치(fail-fast) 반복기는 최상의 노력으로 throw ConcurrentModificationException
합니다. 따라서 이 예외의 정확성 에 의존하는 프로그램을 작성하는 것은 잘못된 일입니다. 반복기의 장애 조치(fail-fast) 동작은 버그를 감지하는 데만 사용해야 합니다.
Java 2 플랫폼 v1.2를 기준으로 이 클래스는 인터페이스를 구현 Map
하도록 개조되어 해당 클래스를 의 멤버로 만듭니다.
Java 컬렉션 프레임워크. 새 컬렉션 구현과 Hashtable
달리 동기화됩니다. 스레드로부터 안전한 구현이 필요하지 않은 경우 대신 사용하는 HashMap
Hashtable
것이 좋습니다. 스레드로부터 안전한 동시 구현을 원하는 경우 대신 사용하는 java.util.concurrent.ConcurrentHashMap
Hashtable
것이 좋습니다.
1.0에 추가되었습니다.
에 대한 java.util.Hashtable
Java 설명서
이 페이지의 일부는 Android 오픈 소스 프로젝트에서 만들고 공유하고 Creative Commons 2.5 특성 라이선스에 설명된 용어에 따라 사용되는 작업을 기반으로 하는 수정 사항입니다.
생성자
Hashtable() |
기본 초기 용량(11) 및 로드 팩터(0)를 사용하여 비어 있는 새 해시 테이블을 생성합니다. |
Hashtable(IDictionary) |
지정된 맵과 동일한 매핑을 사용하여 새 해시 테이블을 생성합니다. |
Hashtable(Int32) |
지정된 초기 용량 및 기본 로드 팩터(0)를 사용하여 비어 있는 새 해시 테이블을 생성합니다. |
Hashtable(Int32, Single) |
지정된 초기 용량 및 지정된 로드 팩터를 사용하여 비어 있는 새 해시 테이블을 생성합니다. |
Hashtable(IntPtr, JniHandleOwnership) |
JNI 개체의 관리되는 표현을 만들 때 사용되는 생성자입니다. 런타임에서 호출합니다. |
속성
Class |
이 |
Handle |
기본 Android 인스턴스에 대한 핸들입니다. (다음에서 상속됨 Object) |
IsEmpty |
이 해시 테이블이 값에 키를 매핑하지 않는지 테스트합니다. |
JniIdentityHashCode |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. (다음에서 상속됨 Object) |
JniPeerMembers |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. |
PeerReference |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. (다음에서 상속됨 Object) |
ThresholdClass |
이 API는 Android용 Mono 인프라를 지원하며 코드에서 직접 사용할 수 없습니다. |
ThresholdType |
이 API는 Android용 Mono 인프라를 지원하며 코드에서 직접 사용할 수 없습니다. |
메서드
Clear() |
키가 포함되지 않도록 이 해시 테이블을 지웁니다. |
Clone() |
이 해시 테이블의 단순 복사본을 만듭니다. |
Compute(Object, IBiFunction) |
추가할 수 있습니다. |
ComputeIfAbsent(Object, IFunction) |
추가할 수 있습니다. |
ComputeIfPresent(Object, IBiFunction) |
추가할 수 있습니다. |
Contains(Object) |
일부 키가 이 해시 테이블의 지정된 값에 매핑되는지 테스트합니다. |
ContainsKey(Object) |
지정된 개체가 이 해시 테이블의 키인지 테스트합니다. |
ContainsValue(Object) |
이 해시 테이블이 하나 이상의 키를 이 값에 매핑하면 true를 반환합니다. |
Dispose() |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. (다음에서 상속됨 Object) |
Dispose(Boolean) |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. (다음에서 상속됨 Object) |
Elements() |
이 해시 테이블의 값 열거형을 반환합니다. |
EntrySet() |
|
Equals(Object) |
다른 개체가 이 개체와 "같음"인지 여부를 나타냅니다. (다음에서 상속됨 Object) |
ForEach(IBiConsumer) |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. |
Get(Object) |
지정된 키가 매핑되는 값을 반환하거나 |
GetHashCode() |
개체에 대한 해시 코드 값을 반환합니다. (다음에서 상속됨 Object) |
GetOrDefault(Object, Object) |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. |
JavaFinalize() |
가비지 수집에서 개체에 대한 참조가 더 이상 없다고 판단할 때 개체의 가비지 수집기에서 호출됩니다. (다음에서 상속됨 Object) |
Keys() |
이 해시 테이블의 키 열거형을 반환합니다. |
KeySet() |
|
Merge(Object, Object, IBiFunction) |
추가할 수 있습니다. |
Notify() |
이 개체의 모니터에서 대기 중인 단일 스레드를 해제합니다. (다음에서 상속됨 Object) |
NotifyAll() |
이 개체의 모니터에서 대기 중인 모든 스레드를 해제합니다. (다음에서 상속됨 Object) |
Put(Object, Object) |
지정된 |
PutAll(IDictionary) |
지정된 맵의 모든 매핑을 이 해시 테이블로 복사합니다. |
PutIfAbsent(Object, Object) |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. |
Rehash() |
항목을 보다 효율적으로 수용하고 액세스하기 위해 이 해시 테이블의 용량을 늘리고 내부적으로 재구성합니다. |
Remove(Object) |
이 해시 테이블에서 키(및 해당 값)를 제거합니다. |
Remove(Object, Object) |
이 해시 테이블에서 키(및 해당 값)를 제거합니다. |
Replace(Object, Object) |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. |
Replace(Object, Object, Object) |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. |
ReplaceAll(IBiFunction) |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. |
SetHandle(IntPtr, JniHandleOwnership) |
Handle 속성을 설정합니다. (다음에서 상속됨 Object) |
Size() |
이 해시 테이블의 키 수를 반환합니다. |
ToArray<T>() |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. (다음에서 상속됨 Object) |
ToString() |
개체의 문자열 표현을 반환합니다. (다음에서 상속됨 Object) |
UnregisterFromRuntime() |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. (다음에서 상속됨 Object) |
Values() |
|
Wait() |
현재 스레드가 각성될 때까지 대기하게 하며, 일반적으로 <알림을 받<>거나 <><중단/종료>합니다.> (다음에서 상속됨 Object) |
Wait(Int64) |
현재 스레드가 각성될 때까지 대기하게 하며, 일반적으로 <>알림을 받<거나 <중단/>종료><>하거나 일정량의 실시간 경과가 발생할 때까지 대기합니다. (다음에서 상속됨 Object) |
Wait(Int64, Int32) |
현재 스레드가 각성될 때까지 대기하게 하며, 일반적으로 <>알림을 받<거나 <중단/>종료><>하거나 일정량의 실시간 경과가 발생할 때까지 대기합니다. (다음에서 상속됨 Object) |
명시적 인터페이스 구현
IJavaPeerable.Disposed() |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. (다음에서 상속됨 Object) |
IJavaPeerable.DisposeUnlessReferenced() |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. (다음에서 상속됨 Object) |
IJavaPeerable.Finalized() |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. (다음에서 상속됨 Object) |
IJavaPeerable.JniManagedPeerState |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. (다음에서 상속됨 Object) |
IJavaPeerable.SetJniIdentityHashCode(Int32) |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. (다음에서 상속됨 Object) |
IJavaPeerable.SetJniManagedPeerState(JniManagedPeerStates) |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. (다음에서 상속됨 Object) |
IJavaPeerable.SetPeerReference(JniObjectReference) |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. (다음에서 상속됨 Object) |
확장 메서드
JavaCast<TResult>(IJavaObject) |
Android 런타임 확인 형식 변환을 수행합니다. |
JavaCast<TResult>(IJavaObject) |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. |
GetJniTypeName(IJavaPeerable) |
이 클래스는 키를 값에 매핑하는 해시 테이블을 구현합니다. |