AbstractInterruptibleChannel Klasse
Definition
Wichtig
Einige Informationen beziehen sich auf Vorabversionen, die vor dem Release ggf. grundlegend überarbeitet werden. Microsoft übernimmt hinsichtlich der hier bereitgestellten Informationen keine Gewährleistungen, seien sie ausdrücklich oder konkludent.
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
- 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 |
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. |