Freigeben über


DatagramChannel Klasse

Definition

Ein auswählbarer Kanal für datagramorientierte Sockets.

[Android.Runtime.Register("java/nio/channels/DatagramChannel", DoNotGenerateAcw=true)]
public abstract class DatagramChannel : Java.Nio.Channels.Spi.AbstractSelectableChannel, IDisposable, Java.Interop.IJavaPeerable, Java.Nio.Channels.IByteChannel, Java.Nio.Channels.IGatheringByteChannel, Java.Nio.Channels.IScatteringByteChannel
[<Android.Runtime.Register("java/nio/channels/DatagramChannel", DoNotGenerateAcw=true)>]
type DatagramChannel = class
    inherit AbstractSelectableChannel
    interface IByteChannel
    interface IReadableByteChannel
    interface IChannel
    interface ICloseable
    interface IJavaObject
    interface IDisposable
    interface IJavaPeerable
    interface IWritableByteChannel
    interface IGatheringByteChannel
    interface IScatteringByteChannel
Vererbung
Attribute
Implementiert

Hinweise

Ein auswählbarer Kanal für datagramorientierte Sockets.

Ein Datagrammkanal wird durch Aufrufen einer der #open open Methoden dieser Klasse erstellt. Es ist nicht möglich, einen Kanal für einen beliebigen, bereits vorhandenen Datagrammsocket zu erstellen. Ein neu erstellter Datagrammkanal ist geöffnet, aber nicht verbunden. Ein Datagrammkanal muss nicht verbunden werden, damit die #send send verwendeten Methoden verwendet #receive receive werden können. Ein Datagrammkanal kann durch Aufrufen seiner #connect connect Methode verbunden werden, um den Aufwand der Sicherheitsüberprüfungen zu vermeiden, die andernfalls als Teil jedes Sende- und Empfangsvorgangs ausgeführt werden. Ein Datagrammkanal muss verbunden sein, um die #read(java.nio.ByteBuffer) read Methoden #write(java.nio.ByteBuffer) write zu verwenden, da diese Methoden keine Socketadressen akzeptieren oder zurückgeben.

Nach der Verbindung bleibt ein Datagrammkanal verbunden, bis er getrennt oder geschlossen wird. Gibt an, ob ein Datagrammkanal verbunden ist, kann durch aufrufende #isConnected isConnected Methode bestimmt werden.

Socketoptionen werden mithilfe der #setOption(SocketOption,Object) setOption Methode konfiguriert. Ein Datagrammkanal zu einem Internetprotokollsocket unterstützt die folgenden Optionen: <blockquote<>table class="striped"><caption style="display:none">Socket options</caption<>thead<>tr><th scope="col">Option Name</th th<>scope="col">Description</th></tr<>/thead><tbody><tr><th scope="row"<java.net.StandardSocketOptions#SO_SNDBUF SO_SNDBUF>/th><td> Die Größe des Socket send buffer </td></tr tr>><<th scope="row"java.net.StandardSocketOptions#SO_RCVBUF SO_RCVBUF></th<>td> Die Größe des Sockets receive buffer </td<>/tr tr<><>th scope="row"<java.net.StandardSocketOptions#SO_REUSEADDR SO_REUSEADDR>/th><td> Re-use address </td<>/tr>><<th scope="row">java.net.StandardSocketOptions#SO_BROADCAST SO_BROADCAST</th><td> Allow transmission of broadcast datagrams </td<>/tr><tr>th scope="row"<java.net.StandardSocketOptions#IP_TOS IP_TOS>/th<>td> The Type of Service (ToS) octet in the Internet Protocol (IP) header </td<>/tr tr>><<th scope="row"><java.net.StandardSocketOptions#IP_MULTICAST_IF IP_MULTICAST_IF/th<>td> The network interface for Internet Protocol (IP) multicast datagrams </td<>/tr tr<><>th scope="row"java.net.StandardSocketOptions#IP_MULTICAST_TTL IP_MULTICAST_TTL<>/th><td> The <em>time-to-live</em>< für Multicast-Multicast-Datagramme </td></tr tr><tr><th scope="row">java.net.StandardSocketOptions#IP_MULTICAST_LOOP IP_MULTICAST_LOOP</th><td> Loopback for Internet Protocol (IP) multicast datagrams </td></tr/tbody><<>/table></blockquote> Additional (implementierungsspezifische) Optionen können ebenfalls unterstützt werden.

Datagrammkanäle sind sicher für die Verwendung durch mehrere gleichzeitige Threads. Sie unterstützen gleichzeitiges Lesen und Schreiben, obwohl höchstens ein Thread gelesen werden kann und höchstens ein Thread zu einem bestimmten Zeitpunkt geschrieben werden kann.

In 1.4 hinzugefügt.

Java-Dokumentation für java.nio.channels.DatagramChannel.

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

DatagramChannel(IntPtr, JniHandleOwnership)

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

DatagramChannel(SelectorProvider)

Initialisiert eine neue Instanz dieser Klasse.

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)
IsBlocking

Gibt an, ob sich dieser Kanal im Sperrmodus befindet.

(Geerbt von AbstractSelectableChannel)
IsConnected

Gibt zurück, ob der Socket dieses Kanals verbunden ist oder nicht.

IsOpen

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

(Geerbt von AbstractInterruptibleChannel)
IsRegistered

Gibt an, ob dieser Kanal mit einer oder mehreren Selektoren registriert ist.

(Geerbt von AbstractSelectableChannel)
JniIdentityHashCode

Ein auswählbarer Kanal für datagramorientierte Sockets.

(Geerbt von Object)
JniPeerMembers

Ein auswählbarer Kanal für datagramorientierte Sockets.

LocalAddress

Ein auswählbarer Kanal für datagramorientierte Sockets.

PeerReference

Ein auswählbarer Kanal für datagramorientierte Sockets.

(Geerbt von Object)
RemoteAddress

Ein auswählbarer Kanal für datagramorientierte Sockets.

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.

(Geerbt von AbstractInterruptibleChannel)
Bind(SocketAddress)

Hinzugefügt in 1.

BlockingLock()

Ruft das Objekt ab, das für die Synchronisierung von register und configureBlocking.

(Geerbt von AbstractSelectableChannel)
Clone()

Erstellt und gibt eine Kopie dieses Objekts zurück.

(Geerbt von Object)
Close()

Schließt diesen Kanal.

(Geerbt von AbstractInterruptibleChannel)
ConfigureBlocking(Boolean)

Passt den Blockierungsmodus dieses Kanals an.

(Geerbt von AbstractSelectableChannel)
Connect(SocketAddress)

Verbindet den Socket dieses Kanals.

ConnectAsync(SocketAddress)

Ein auswählbarer Kanal für datagramorientierte Sockets.

Disconnect()

Trennt den Socket dieses Kanals.

Dispose()

Ein auswählbarer Kanal für datagramorientierte Sockets.

(Geerbt von Object)
Dispose(Boolean)

Ein auswählbarer Kanal für datagramorientierte Sockets.

(Geerbt von Object)
End(Boolean)

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

(Geerbt von AbstractInterruptibleChannel)
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.

(Geerbt von AbstractSelectableChannel)
ImplCloseSelectableChannel()

Schließt diesen auswählbaren Kanal.

(Geerbt von AbstractSelectableChannel)
ImplConfigureBlocking(Boolean)

Passt den Blockierungsmodus dieses Kanals an.

(Geerbt von AbstractSelectableChannel)
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)
KeyFor(Selector)

Ruft den Auswahlschlüssel dieses Kanals für den angegebenen Selektor ab.

(Geerbt von AbstractSelectableChannel)
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)
Open()

Öffnet einen Datagrammkanal.

Open(IProtocolFamily)

Öffnet einen Datagrammkanal.

Provider()

Gibt den Anbieter zurück, der diesen Kanal erstellt hat.

(Geerbt von AbstractSelectableChannel)
Read(ByteBuffer)

Liest ein Datagramm aus diesem Kanal.

Read(ByteBuffer[])

Liest ein Datagramm aus diesem Kanal.

Read(ByteBuffer[], Int32, Int32)

Liest ein Datagramm aus diesem Kanal.

Receive(ByteBuffer)

Empfängt ein Datagramm über diesen Kanal.

ReceiveAsync(ByteBuffer)

Ein auswählbarer Kanal für datagramorientierte Sockets.

Register(Selector, Operations)

Registriert diesen Kanal mit der angegebenen Auswahl, wobei eine Auswahltaste zurückgegeben wird.

(Geerbt von SelectableChannel)
Register(Selector, Operations, Object)

Registriert diesen Kanal mit der angegebenen Auswahl, wobei eine Auswahltaste zurückgegeben wird.

(Geerbt von AbstractSelectableChannel)
Send(ByteBuffer, SocketAddress)

Sendet ein Datagramm über diesen Kanal.

SendAsync(ByteBuffer, SocketAddress)

Ein auswählbarer Kanal für datagramorientierte Sockets.

SetHandle(IntPtr, JniHandleOwnership)

Legt die Handle-Eigenschaft fest.

(Geerbt von Object)
SetOption(ISocketOption, Object)

Hinzugefügt in 1.

Socket()

Ruft einen diesem Kanal zugeordneten Datagrammsocket ab.

ToArray<T>()

Ein auswählbarer Kanal für datagramorientierte Sockets.

(Geerbt von Object)
ToString()

Gibt eine Zeichenfolgendarstellung des Objekts zurück.

(Geerbt von Object)
UnregisterFromRuntime()

Ein auswählbarer Kanal für datagramorientierte Sockets.

(Geerbt von Object)
ValidOps()

Gibt einen Vorgangssatz zurück, der die unterstützten Vorgänge dieses Kanals identifiziert.

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)

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, 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)
Write(ByteBuffer)

Schreibt ein Datagramm in diesen Kanal.

Write(ByteBuffer[])

Schreibt ein Datagramm in diesen Kanal.

Write(ByteBuffer[], Int32, Int32)

Schreibt ein Datagramm in diesen Kanal.

Explizite Schnittstellenimplementierungen

IJavaPeerable.Disposed()

Ein auswählbarer Kanal für datagramorientierte Sockets.

(Geerbt von Object)
IJavaPeerable.DisposeUnlessReferenced()

Ein auswählbarer Kanal für datagramorientierte Sockets.

(Geerbt von Object)
IJavaPeerable.Finalized()

Ein auswählbarer Kanal für datagramorientierte Sockets.

(Geerbt von Object)
IJavaPeerable.JniManagedPeerState

Ein auswählbarer Kanal für datagramorientierte Sockets.

(Geerbt von Object)
IJavaPeerable.SetJniIdentityHashCode(Int32)

Ein auswählbarer Kanal für datagramorientierte Sockets.

(Geerbt von Object)
IJavaPeerable.SetJniManagedPeerState(JniManagedPeerStates)

Ein auswählbarer Kanal für datagramorientierte Sockets.

(Geerbt von Object)
IJavaPeerable.SetPeerReference(JniObjectReference)

Ein auswählbarer Kanal für datagramorientierte Sockets.

(Geerbt von Object)

Erweiterungsmethoden

JavaCast<TResult>(IJavaObject)

Führt eine android-laufzeitgecheckte Typkonvertierung aus.

JavaCast<TResult>(IJavaObject)

Ein auswählbarer Kanal für datagramorientierte Sockets.

GetJniTypeName(IJavaPeerable)

Ein auswählbarer Kanal für datagramorientierte Sockets.

WriteAsync(IGatheringByteChannel, ByteBuffer[])

Ein auswählbarer Kanal für datagramorientierte Sockets.

WriteAsync(IGatheringByteChannel, ByteBuffer[], Int32, Int32)

Ein auswählbarer Kanal für datagramorientierte Sockets.

ReadAsync(IReadableByteChannel, ByteBuffer)

Ein auswählbarer Kanal für datagramorientierte Sockets.

ReadAsync(IScatteringByteChannel, ByteBuffer[])

Ein auswählbarer Kanal für datagramorientierte Sockets.

ReadAsync(IScatteringByteChannel, ByteBuffer[], Int32, Int32)

Ein auswählbarer Kanal für datagramorientierte Sockets.

WriteAsync(IWritableByteChannel, ByteBuffer)

Ein auswählbarer Kanal für datagramorientierte Sockets.

Gilt für: