PriorityBlockingQueue 클래스
정의
중요
일부 정보는 릴리스되기 전에 상당 부분 수정될 수 있는 시험판 제품과 관련이 있습니다. Microsoft는 여기에 제공된 정보에 대해 어떠한 명시적이거나 묵시적인 보증도 하지 않습니다.
클래스 PriorityQueue
와 동일한 순서 규칙을 사용하고 검색 작업을 차단하는 바인딩되지 않은 BlockingQueue 차단 큐입니다.
[Android.Runtime.Register("java/util/concurrent/PriorityBlockingQueue", DoNotGenerateAcw=true)]
[Java.Interop.JavaTypeParameters(new System.String[] { "E" })]
public class PriorityBlockingQueue : Java.Util.AbstractQueue, IDisposable, Java.Interop.IJavaPeerable, Java.IO.ISerializable, Java.Util.Concurrent.IBlockingQueue
[<Android.Runtime.Register("java/util/concurrent/PriorityBlockingQueue", DoNotGenerateAcw=true)>]
[<Java.Interop.JavaTypeParameters(new System.String[] { "E" })>]
type PriorityBlockingQueue = class
inherit AbstractQueue
interface ISerializable
interface IJavaObject
interface IDisposable
interface IJavaPeerable
interface IBlockingQueue
interface IQueue
interface ICollection
interface IIterable
- 상속
- 특성
- 구현
설명
클래스 PriorityQueue
와 동일한 순서 규칙을 사용하고 검색 작업을 차단하는 바인딩되지 않은 BlockingQueue 차단 큐입니다. 이 큐는 논리적으로 바인딩되지 않지만 리소스 소모(원인 OutOfMemoryError
)로 인해 추가 시도가 실패할 수 있습니다. 이 클래스는 요소를 허용하지 null
않습니다. 비교 가능한 자연 순서 지정을 사용하는 우선 순위 큐는 비교할 수 없는 개체의 삽입도 허용하지 않습니다(이렇게 하면 ClassCastException
).
이 클래스와 해당 반복기는 및 인터페이스의 <모든 em>선택적</em> 메서드를 Collection
구현 Iterator
합니다. 메서드에 제공된 반복기와 메서드 #iterator()
에 제공된 Spliterator는>< PriorityBlockingQueue의 요소를 특정 순서로 트래버스하도록 보장되지 않습니다><.#spliterator()
순서가 지정된 순회가 필요한 경우 를 사용하는 Arrays.sort(pq.toArray())
것이 좋습니다. 또한 메서드 drainTo
를 <>사용하여 일부 또는 모든 요소를 우선 순위 순서로 제거</제거하고> 다른 컬렉션에 배치할 수 있습니다.
이 클래스에 대한 작업은 우선 순위가 같은 요소의 순서를 보장하지 않습니다. 순서 지정을 적용해야 하는 경우 보조 키를 사용하여 기본 우선 순위 값의 관계를 끊는 사용자 지정 클래스 또는 비교자를 정의할 수 있습니다. 예를 들어 다음은 비교 가능한 요소에 선입선 실행 동률을 적용하는 클래스입니다. 이를 사용하려면 일반 항목 개체 대신 를 삽입 new FIFOEntry(anEntry)
합니다.
{@code
class FIFOEntry<E extends Comparable<? super E>>
implements Comparable<FIFOEntry<E>> {
static final AtomicLong seq = new AtomicLong();
final long seqNum;
final E entry;
public FIFOEntry(E entry) {
seqNum = seq.getAndIncrement();
this.entry = entry;
}
public E getEntry() { return entry; }
public int compareTo(FIFOEntry<E> other) {
int res = entry.compareTo(other.entry);
if (res == 0 && other.entry != this.entry)
res = (seqNum < other.seqNum ? -1 : 1);
return res;
}
}}
이 클래스는 Java Collections Framework의 멤버입니다.
1.5에 추가되었습니다.
에 대한 Java 설명서입니다 java.util.concurrent.PriorityBlockingQueue
.
이 페이지의 일부는 만들고 공유하며 에 설명된 용어에 따라 사용되는 작업을 기반으로 수정됩니다.
생성자
PriorityBlockingQueue() |
|
PriorityBlockingQueue(ICollection) |
|
PriorityBlockingQueue(Int32) |
|
PriorityBlockingQueue(Int32, IComparator) |
|
PriorityBlockingQueue(IntPtr, JniHandleOwnership) |
JNI 개체의 관리되는 표현을 만들 때 사용되는 생성자입니다. 런타임에서 호출합니다. |
속성
Class |
이 |
Handle |
기본 Android instance 대한 핸들입니다. (다음에서 상속됨 Object) |
IsEmpty |
추가할 항목 (다음에서 상속됨 AbstractCollection) |
JniIdentityHashCode |
클래스 |
JniPeerMembers |
클래스 |
PeerReference |
클래스 |
ThresholdClass |
이 API는 Android용 Mono 인프라를 지원하며 코드에서 직접 사용할 수 없습니다. |
ThresholdType |
이 API는 Android용 Mono 인프라를 지원하며 코드에서 직접 사용할 수 없습니다. |
메서드
Add(Object) |
추가할 항목 (다음에서 상속됨 AbstractCollection) |
AddAll(ICollection) |
추가할 항목 (다음에서 상속됨 AbstractCollection) |
Clear() |
추가할 항목 (다음에서 상속됨 AbstractCollection) |
Clone() |
이 개체의 복사본을 만들고 반환합니다. (다음에서 상속됨 Object) |
Comparator() |
이 큐의 요소를 정렬하는 데 사용되는 비교자를 반환하거나 |
Contains(Object) |
추가할 항목 (다음에서 상속됨 AbstractCollection) |
ContainsAll(ICollection) |
추가할 항목 (다음에서 상속됨 AbstractCollection) |
Dispose() |
클래스 |
Dispose(Boolean) |
클래스 |
DrainTo(ICollection) |
클래스 |
DrainTo(ICollection, Int32) |
클래스 |
Element() |
이 큐의 헤드를 검색하지만 제거하지는 않습니다. (다음에서 상속됨 AbstractQueue) |
Equals(Object) |
다른 개체가 이 개체와 "같음"인지 여부를 나타냅니다. (다음에서 상속됨 Object) |
ForEach(IConsumer) |
클래스 |
GetHashCode() |
개체의 해시 코드 값을 반환합니다. (다음에서 상속됨 Object) |
Iterator() |
이 큐의 요소에 대한 반복기를 반환합니다. |
JavaFinalize() |
가비지 수집에서 개체에 대한 참조가 더 이상 없다고 판단할 때 개체의 가비지 수집기에서 호출됩니다. (다음에서 상속됨 Object) |
Notify() |
이 개체의 모니터에서 대기 중인 단일 스레드를 해제합니다. (다음에서 상속됨 Object) |
NotifyAll() |
이 개체의 모니터에서 대기 중인 모든 스레드를 해제합니다. (다음에서 상속됨 Object) |
Offer(Object) |
지정된 요소를 이 우선 순위 큐에 삽입합니다. |
Offer(Object, Int64, TimeUnit) |
지정된 요소를 이 우선 순위 큐에 삽입합니다. |
Peek() |
이 큐의 헤드를 검색하지만 제거하지는 않으며 이 큐가 비어 있으면 를 반환 |
Poll() |
이 큐의 헤드를 검색 및 제거하거나 이 큐가 비어 있으면 를 반환합니다 |
Poll(Int64, TimeUnit) |
요소를 사용할 수 있도록 필요한 경우 지정된 대기 시간까지 대기하여 이 큐의 헤드를 검색하고 제거합니다. |
Put(Object) |
지정된 요소를 이 우선 순위 큐에 삽입합니다. |
RemainingCapacity() |
는 |
Remove() |
이 큐의 헤드를 검색하고 제거합니다. (다음에서 상속됨 AbstractQueue) |
Remove(Object) |
추가할 항목 (다음에서 상속됨 AbstractCollection) |
RemoveAll(ICollection) |
추가할 항목 (다음에서 상속됨 AbstractCollection) |
RemoveIf(IPredicate) |
클래스 |
RetainAll(ICollection) |
추가할 항목 (다음에서 상속됨 AbstractCollection) |
SetHandle(IntPtr, JniHandleOwnership) |
Handle 속성을 설정합니다. (다음에서 상속됨 Object) |
Size() |
이 |
Spliterator() |
|
Take() |
요소를 사용할 수 있게 될 때까지 필요한 경우 대기하여 이 큐의 헤드를 검색하고 제거합니다. |
ToArray() |
추가할 항목 (다음에서 상속됨 AbstractCollection) |
ToArray(Object[]) |
추가할 항목 (다음에서 상속됨 AbstractCollection) |
ToArray<T>() |
클래스 |
ToString() |
개체의 문자열 표현을 반환합니다. (다음에서 상속됨 Object) |
UnregisterFromRuntime() |
클래스 |
Wait() |
현재 스레드가 각성될 때까지 대기하도록 합니다. 일반적으로 <알림을<> 받>거나<<> 중단/em>합니다. (다음에서 상속됨 Object) |
Wait(Int64) |
현재 스레드가 깨어날 때까지 대기하게 하며, 일반적으로 <알림을 받<>거나 중단</>em>>을 받거나 <일정량의 실시간이 경과할 때까지 대기합니다. (다음에서 상속됨 Object) |
Wait(Int64, Int32) |
현재 스레드가 깨어날 때까지 대기하게 하며, 일반적으로 <알림을 받<>거나 중단</>em>>을 받거나 <일정량의 실시간이 경과할 때까지 대기합니다. (다음에서 상속됨 Object) |
명시적 인터페이스 구현
IJavaPeerable.Disposed() |
클래스 |
IJavaPeerable.DisposeUnlessReferenced() |
클래스 |
IJavaPeerable.Finalized() |
클래스 |
IJavaPeerable.JniManagedPeerState |
클래스 |
IJavaPeerable.SetJniIdentityHashCode(Int32) |
클래스 |
IJavaPeerable.SetJniManagedPeerState(JniManagedPeerStates) |
클래스 |
IJavaPeerable.SetPeerReference(JniObjectReference) |
클래스 |
확장 메서드
JavaCast<TResult>(IJavaObject) |
Android 런타임 확인 형식 변환을 수행합니다. |
JavaCast<TResult>(IJavaObject) |
클래스 |
GetJniTypeName(IJavaPeerable) |
클래스 |
OfferAsync(IBlockingQueue, Object) |
클래스 |
OfferAsync(IBlockingQueue, Object, Int64, TimeUnit) |
클래스 |
PollAsync(IBlockingQueue, Int64, TimeUnit) |
클래스 |
PutAsync(IBlockingQueue, Object) |
클래스 |
TakeAsync(IBlockingQueue) |
클래스 |
ToEnumerable(IIterable) |
클래스 |
ToEnumerable<T>(IIterable) |
클래스 |