Freigeben über


AbstractInterruptibleChannel Klasse

Definition

Basisimplementierungsklasse für unterbrechungsfähige Kanäle.

[Android.Runtime.Register("java/nio/channels/spi/AbstractInterruptibleChannel", DoNotGenerateAcw=true)]
public abstract class AbstractInterruptibleChannel : Java.Lang.Object, IDisposable, Java.Interop.IJavaPeerable, Java.Nio.Channels.IInterruptibleChannel
[<Android.Runtime.Register("java/nio/channels/spi/AbstractInterruptibleChannel", DoNotGenerateAcw=true)>]
type AbstractInterruptibleChannel = class
    inherit Object
    interface IChannel
    interface ICloseable
    interface IJavaObject
    interface IDisposable
    interface IJavaPeerable
    interface IInterruptibleChannel
Vererbung
AbstractInterruptibleChannel
Abgeleitet
Attribute
Implementiert

Hinweise

Basisimplementierungsklasse für unterbrechungsfähige Kanäle.

Diese Klasse kapselt die Maschinen auf niedriger Ebene, die zum Implementieren der asynchronen Schließung und Unterbrechung von Kanälen erforderlich sind. Eine konkrete Kanalklasse muss die #begin begin Methoden #end end und Methoden vor bzw. nachher aufrufen, um einen E/A-Vorgang aufzurufen, der auf unbestimmte Zeit blockiert werden kann. Um sicherzustellen, dass die #end end Methode immer aufgerufen wird, sollten diese Methoden in einem try ...  finally Block:

<Blockquote>

boolean completed = false;
            try {
                begin();
                completed = ...;    // Perform blocking I/O operation
                return ...;         // Return result
            } finally {
                end(completed);
            }

</blockquote>

Das completed Argument an die #end end Methode gibt an, ob der E/A-Vorgang tatsächlich abgeschlossen wurde, d. h. ob er Auswirkungen hatte, die für den Aufrufer sichtbar wären. Bei einem Vorgang, der Beispielsweise Bytes liest, sollte dieses Argument nur dann sein true , wenn einige Bytes tatsächlich in den Zielpuffer des Aufrufers übertragen wurden.

Eine konkrete Kanalklasse muss die #implCloseChannel implCloseChannel Methode auch so implementieren, dass, wenn sie aufgerufen wird, während ein anderer Thread in einem systemeigenen E/A-Vorgang auf dem Kanal blockiert wird, dann wird dieser Vorgang sofort zurückgegeben, entweder durch Auslösen einer Ausnahme oder durch Zurückgeben normal. Wenn ein Thread unterbrochen wird oder der Kanal, auf dem er blockiert wird, asynchron geschlossen wird, löst die Methode des Kanals #end end die entsprechende Ausnahme aus.

Diese Klasse führt die Synchronisierung aus, die zum Implementieren der java.nio.channels.Channel Spezifikation erforderlich ist. Implementierungen der #implCloseChannel implCloseChannel Methode müssen nicht mit anderen Threads synchronisiert werden, die möglicherweise versuchen, den Kanal zu schließen.

In 1.4 hinzugefügt.

Java-Dokumentation für java.nio.channels.spi.AbstractInterruptibleChannel.

Teile dieser Seite sind Änderungen auf der Grundlage von Arbeiten, die vom Android Open Source-Projekt erstellt und freigegeben werden und gemäß den in der Creative Commons 2.5 Attribution License beschriebenen Begriffen verwendet werden.

Konstruktoren

AbstractInterruptibleChannel()

Initialisiert eine neue Instanz dieser Klasse.

AbstractInterruptibleChannel(IntPtr, JniHandleOwnership)

Ein Konstruktor, der beim Erstellen verwalteter Darstellungen von JNI-Objekten verwendet wird; wird von der Laufzeit aufgerufen.

Eigenschaften

Class

Gibt die Laufzeitklasse dieses Werts Objectzurück.

(Geerbt von Object)
Handle

Das Handle für die zugrunde liegende Android-Instanz.

(Geerbt von Object)
IsOpen

Gibt true zurück, wenn dieser Kanal geöffnet ist.

JniIdentityHashCode

Basisimplementierungsklasse für unterbrechungsfähige Kanäle.

(Geerbt von Object)
JniPeerMembers

Basisimplementierungsklasse für unterbrechungsfähige Kanäle.

PeerReference

Basisimplementierungsklasse für unterbrechungsfähige Kanäle.

(Geerbt von Object)
ThresholdClass

Diese API unterstützt die Mono für Android-Infrastruktur und ist nicht für die direkte Verwendung aus Ihrem Code vorgesehen.

ThresholdType

Diese API unterstützt die Mono für Android-Infrastruktur und ist nicht für die direkte Verwendung aus Ihrem Code vorgesehen.

Methoden

Begin()

Markiert den Anfang eines E/A-Vorgangs, der auf unbestimmte Zeit blockiert werden kann.

Clone()

Erstellt und gibt eine Kopie dieses Objekts zurück.

(Geerbt von Object)
Close()

Schließt diesen Kanal.

Dispose()

Basisimplementierungsklasse für unterbrechungsfähige Kanäle.

(Geerbt von Object)
Dispose(Boolean)

Basisimplementierungsklasse für unterbrechungsfähige Kanäle.

(Geerbt von Object)
End(Boolean)

Markiert das Ende eines E/A-Vorgangs, der auf unbestimmte Zeit blockiert werden kann.

Equals(Object)

Gibt an, ob ein anderes Objekt "gleich" diesem Objekt ist.

(Geerbt von Object)
GetHashCode()

Gibt einen Hashcodewert für das Objekt zurück.

(Geerbt von Object)
ImplCloseChannel()

Schließt diesen Kanal.

JavaFinalize()

Wird vom Garbage Collector für ein Objekt aufgerufen, wenn die Garbage Collection bestimmt, dass keine weiteren Verweise auf das Objekt vorhanden sind.

(Geerbt von Object)
Notify()

Aktiviert einen einzelnen Thread, der auf dem Monitor dieses Objekts wartet.

(Geerbt von Object)
NotifyAll()

Aktiviert alle Threads, die auf dem Monitor dieses Objekts warten.

(Geerbt von Object)
SetHandle(IntPtr, JniHandleOwnership)

Legt die Handle-Eigenschaft fest.

(Geerbt von Object)
ToArray<T>()

Basisimplementierungsklasse für unterbrechungsfähige Kanäle.

(Geerbt von Object)
ToString()

Gibt eine Zeichenfolgendarstellung des Objekts zurück.

(Geerbt von Object)
UnregisterFromRuntime()

Basisimplementierungsklasse für unterbrechungsfähige Kanäle.

(Geerbt von Object)
Wait()

Bewirkt, dass der aktuelle Thread wartet, bis er wach ist, in der Regel durch em benachrichtigt/em> oder <em>unterbrochen</em>.<><

(Geerbt von Object)
Wait(Int64, Int32)

Bewirkt, dass der aktuelle Thread wartet, bis er wach ist, in der Regel durch <em>benachrichtigt</em> oder <em>unterbrochen</em> oder bis eine bestimmte Menge an Echtzeit verstrichen ist.

(Geerbt von Object)
Wait(Int64)

Bewirkt, dass der aktuelle Thread wartet, bis er wach ist, in der Regel durch <em>benachrichtigt</em> oder <em>unterbrochen</em> oder bis eine bestimmte Menge an Echtzeit verstrichen ist.

(Geerbt von Object)

Explizite Schnittstellenimplementierungen

IJavaPeerable.Disposed()

Basisimplementierungsklasse für unterbrechungsfähige Kanäle.

(Geerbt von Object)
IJavaPeerable.DisposeUnlessReferenced()

Basisimplementierungsklasse für unterbrechungsfähige Kanäle.

(Geerbt von Object)
IJavaPeerable.Finalized()

Basisimplementierungsklasse für unterbrechungsfähige Kanäle.

(Geerbt von Object)
IJavaPeerable.JniManagedPeerState

Basisimplementierungsklasse für unterbrechungsfähige Kanäle.

(Geerbt von Object)
IJavaPeerable.SetJniIdentityHashCode(Int32)

Basisimplementierungsklasse für unterbrechungsfähige Kanäle.

(Geerbt von Object)
IJavaPeerable.SetJniManagedPeerState(JniManagedPeerStates)

Basisimplementierungsklasse für unterbrechungsfähige Kanäle.

(Geerbt von Object)
IJavaPeerable.SetPeerReference(JniObjectReference)

Basisimplementierungsklasse für unterbrechungsfähige Kanäle.

(Geerbt von Object)

Erweiterungsmethoden

JavaCast<TResult>(IJavaObject)

Führt eine android-laufzeitgecheckte Typkonvertierung aus.

JavaCast<TResult>(IJavaObject)

Basisimplementierungsklasse für unterbrechungsfähige Kanäle.

GetJniTypeName(IJavaPeerable)

Basisimplementierungsklasse für unterbrechungsfähige Kanäle.

Gilt für: