Freigeben über


Binder Klasse

Definition

Basisklasse für ein remotable-Objekt, der Kernteil eines einfachen Remoteprozeduraufrufmechanismus, der durch definiert wird IBinder.

[Android.Runtime.Register("android/os/Binder", DoNotGenerateAcw=true)]
public class Binder : Java.Lang.Object, Android.OS.IBinder, IDisposable, Java.Interop.IJavaPeerable
[<Android.Runtime.Register("android/os/Binder", DoNotGenerateAcw=true)>]
type Binder = class
    inherit Object
    interface IBinder
    interface IJavaObject
    interface IDisposable
    interface IJavaPeerable
Vererbung
Binder
Attribute
Implementiert

Hinweise

Basisklasse für ein remotable-Objekt, der Kernteil eines einfachen Remoteprozeduraufrufmechanismus, der durch definiert wird IBinder. Diese Klasse ist eine Implementierung von IBinder, die eine standardmäßige lokale Implementierung eines solchen Objekts bereitstellt.

Die meisten Entwickler implementieren diese Klasse nicht direkt, sondern verwenden das Aidl-Tool , um die gewünschte Schnittstelle zu beschreiben, indem sie die entsprechende Binder-Unterklasse generiert. Sie können jedoch direkt von Binder ableiten, um Ihr eigenes benutzerdefiniertes RPC-Protokoll zu implementieren oder einfach ein unformatiertes Binder-Objekt direkt zu instanziieren, um es als Token zu verwenden, das über Prozesse hinweg freigegeben werden kann.

Diese Klasse ist nur ein einfacher IPC-Grundtyp; es hat keine Auswirkungen auf den Lebenszyklus einer Anwendung und ist nur gültig, solange der Prozess, der sie erstellt hat, weiterhin ausgeführt wird. Um dies ordnungsgemäß zu verwenden, müssen Sie dies im Kontext einer Anwendung auf oberster Ebene (a android.app.Service, android.app.Activityoder android.content.ContentProvider) tun, die das System informiert, dass Ihr Prozess weiterhin ausgeführt werden soll.

Sie müssen die Situationen berücksichtigen, in denen Ihr Prozess weggehen könnte, und daher erfordern, dass Sie später einen neuen Binder neu erstellen und ihn erneut anfügen, wenn der Prozess erneut gestartet wird. Wenn Sie dies z. B. innerhalb eines android.app.ActivityVorgangs verwenden, kann der Prozess Ihrer Aktivität jedes Mal beendet werden, wenn die Aktivität nicht gestartet wird. Wenn die Aktivität später neu erstellt wird, müssen Sie einen neuen Ordner erstellen und es wieder an den richtigen Ort übergeben. Sie müssen sich bewusst sein, dass Ihr Prozess möglicherweise aus einem anderen Grund gestartet wird (z. B. um eine Übertragung zu empfangen), die keine erneute Erstellung der Aktivität beinhaltet und somit ausgeführt wird. der Code zum Erstellen eines neuen Binders.

Java-Dokumentation für android.os.Binder.

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

Binder()

Der Standardkonstruktor initialisiert einfach das Objekt.

Binder(IntPtr, JniHandleOwnership)

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

Binder(String)

Konstruktor zum Erstellen eines unformatierten Binder-Objekts (Token) zusammen mit einem Deskriptor.

Eigenschaften

CallingPid

Gibt die ID des Prozesses zurück, der Ihnen die aktuelle Transaktion gesendet hat, die verarbeitet wird.

CallingUid

Geben Sie die Linux-UID zurück, die dem Prozess zugewiesen ist, der Ihnen die aktuelle Transaktion gesendet hat, die verarbeitet wird.

CallingUidOrThrow

Gibt die Linux-UID zurück, die dem Prozess zugewiesen ist, der die aktuell verarbeitete Transaktion gesendet hat.

CallingUserHandle

Gibt das userHandle zurück, das dem Prozess zugewiesen ist, der Ihnen die aktuelle Transaktion gesendet hat, die verarbeitet wird.

CallingWorkSourceUid

Gibt die vom Aufrufer festgelegte Arbeitsquelle zurück.

Class

Gibt die Laufzeitklasse dieses Werts Objectzurück.

(Geerbt von Object)
Handle

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

(Geerbt von Object)
InterfaceDescriptor

Die Standardimplementierung gibt einen leeren Schnittstellennamen zurück.

IsBinderAlive

So wird's hinzugefügt

        Note that if you're calling on a local binder, this always returns true
        because your process is alive if you're calling it.
JniIdentityHashCode

Basisklasse für ein remotable-Objekt, der Kernteil eines einfachen Remoteprozeduraufrufmechanismus, der durch definiert wird IBinder.

(Geerbt von Object)
JniPeerMembers

Basisklasse für ein remotable-Objekt, der Kernteil eines einfachen Remoteprozeduraufrufmechanismus, der durch definiert wird IBinder.

PeerReference

Basisklasse für ein remotable-Objekt, der Kernteil eines einfachen Remoteprozeduraufrufmechanismus, der durch definiert wird IBinder.

(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

AttachInterface(IInterface, String)

Convenience-Methode zum Zuordnen einer bestimmten Schnittstelle zum Binder.

ClearCallingIdentity()

Setzen Sie die Identität des eingehenden IPC im aktuellen Thread zurück.

ClearCallingWorkSource()

Löscht die Arbeitsquelle für diesen Thread.

Clone()

Erstellt und gibt eine Kopie dieses Objekts zurück.

(Geerbt von Object)
Dispose()

Basisklasse für ein remotable-Objekt, der Kernteil eines einfachen Remoteprozeduraufrufmechanismus, der durch definiert wird IBinder.

(Geerbt von Object)
Dispose(Boolean)

Basisklasse für ein remotable-Objekt, der Kernteil eines einfachen Remoteprozeduraufrufmechanismus, der durch definiert wird IBinder.

(Geerbt von Object)
Dump(FileDescriptor, PrintWriter, String[])

Drucken Sie den Zustand des Objekts in den angegebenen Datenstrom.

Dump(FileDescriptor, String[])

Implementiert, um die komfortablere Version #dump(FileDescriptor, PrintWriter, String[])aufzurufen.

DumpAsync(FileDescriptor, String[])

Gefällt #dump(FileDescriptor, String[])mir , stellt jedoch sicher, dass das Ziel asynchron ausgeführt wird.

Equals(Object)

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

(Geerbt von Object)
FlushPendingCommands()

Leeren Sie alle Ordnerbefehle, die im aktuellen Thread an den Kerneltreiber ausstehen.

GetHashCode()

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

(Geerbt von Object)
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)
JoinThreadPool()

Fügen Sie den aufrufenden Thread zum IPC-Threadpool hinzu.

LinkToDeath(IBinderDeathRecipient, Int32)

Die lokale Implementierung ist eine No-Op.

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)
OnTransact(Int32, Parcel, Parcel, Int32)

Die Standardimplementierung ist ein Stub, der "false" zurückgibt.

PingBinder()

Die Standardimplementierung gibt immer true zurück – wenn Sie hier sind, ist das Objekt lebendig.

QueryLocalInterface(String)

Verwenden Sie informationen, die angegeben werden, um #attachInterface attachInterface() den zugeordneten IInterface Wert zurückzugeben, wenn sie mit dem angeforderten Deskriptor übereinstimmt.

RestoreCallingIdentity(Int64)

Stellen Sie die Identität des eingehenden IPC im aktuellen Thread wieder auf eine zuvor zurückgegebene #clearCallingIdentityIdentität zurück.

RestoreCallingWorkSource(Int64)

Stellt die Arbeitsquelle für diesen Thread mithilfe eines von #setCallingWorkSourceUid(int) oder .#clearCallingWorkSource()

SetCallingWorkSourceUid(Int32)

Legt die Arbeitsquelle für diesen Thread fest.

SetHandle(IntPtr, JniHandleOwnership)

Legt die Handle-Eigenschaft fest.

(Geerbt von Object)
ToArray<T>()

Basisklasse für ein remotable-Objekt, der Kernteil eines einfachen Remoteprozeduraufrufmechanismus, der durch definiert wird IBinder.

(Geerbt von Object)
ToString()

Gibt eine Zeichenfolgendarstellung des Objekts zurück.

(Geerbt von Object)
Transact(Int32, Parcel, Parcel, TransactionFlags)

Bei der Standardimplementierung werden die Pakete und Anrufe anTransact zurückspulen.

UnlinkToDeath(IBinderDeathRecipient, Int32)

Die lokale Implementierung ist eine No-Op.

UnregisterFromRuntime()

Basisklasse für ein remotable-Objekt, der Kernteil eines einfachen Remoteprozeduraufrufmechanismus, der durch definiert wird IBinder.

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

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)

Explizite Schnittstellenimplementierungen

IJavaPeerable.Disposed()

Basisklasse für ein remotable-Objekt, der Kernteil eines einfachen Remoteprozeduraufrufmechanismus, der durch definiert wird IBinder.

(Geerbt von Object)
IJavaPeerable.DisposeUnlessReferenced()

Basisklasse für ein remotable-Objekt, der Kernteil eines einfachen Remoteprozeduraufrufmechanismus, der durch definiert wird IBinder.

(Geerbt von Object)
IJavaPeerable.Finalized()

Basisklasse für ein remotable-Objekt, der Kernteil eines einfachen Remoteprozeduraufrufmechanismus, der durch definiert wird IBinder.

(Geerbt von Object)
IJavaPeerable.JniManagedPeerState

Basisklasse für ein remotable-Objekt, der Kernteil eines einfachen Remoteprozeduraufrufmechanismus, der durch definiert wird IBinder.

(Geerbt von Object)
IJavaPeerable.SetJniIdentityHashCode(Int32)

Basisklasse für ein remotable-Objekt, der Kernteil eines einfachen Remoteprozeduraufrufmechanismus, der durch definiert wird IBinder.

(Geerbt von Object)
IJavaPeerable.SetJniManagedPeerState(JniManagedPeerStates)

Basisklasse für ein remotable-Objekt, der Kernteil eines einfachen Remoteprozeduraufrufmechanismus, der durch definiert wird IBinder.

(Geerbt von Object)
IJavaPeerable.SetPeerReference(JniObjectReference)

Basisklasse für ein remotable-Objekt, der Kernteil eines einfachen Remoteprozeduraufrufmechanismus, der durch definiert wird IBinder.

(Geerbt von Object)

Erweiterungsmethoden

JavaCast<TResult>(IJavaObject)

Führt eine android-laufzeitgecheckte Typkonvertierung aus.

JavaCast<TResult>(IJavaObject)

Basisklasse für ein remotable-Objekt, der Kernteil eines einfachen Remoteprozeduraufrufmechanismus, der durch definiert wird IBinder.

GetJniTypeName(IJavaPeerable)

Basisklasse für ein remotable-Objekt, der Kernteil eines einfachen Remoteprozeduraufrufmechanismus, der durch definiert wird IBinder.

Gilt für: