SyncFence 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.
Eine SyncFence stellt einen Synchronisierungsgrundtyp dar, der signalisiert, wenn Hardwareeinheiten die Arbeit an einer bestimmten Ressource abgeschlossen haben.
[Android.Runtime.Register("android/hardware/SyncFence", ApiSince=33, DoNotGenerateAcw=true)]
public sealed class SyncFence : Java.Lang.Object, Android.OS.IParcelable, IDisposable, Java.Interop.IJavaPeerable, Java.Lang.IAutoCloseable
[<Android.Runtime.Register("android/hardware/SyncFence", ApiSince=33, DoNotGenerateAcw=true)>]
type SyncFence = class
inherit Object
interface IParcelable
interface IJavaObject
interface IDisposable
interface IJavaPeerable
interface IAutoCloseable
- Vererbung
- Attribute
- Implementiert
Hinweise
Eine SyncFence stellt einen Synchronisierungsgrundtyp dar, der signalisiert, wenn Hardwareeinheiten die Arbeit an einer bestimmten Ressource abgeschlossen haben. Sie beginnen zunächst in einem nicht signalisierten Zustand und machen einen einmaligen Übergang zu einem Signal- oder Fehlerzustand. SyncFences werden von verschiedenen Geräte-APIs als Reaktion auf das Senden von Aufgaben an das Gerät erstellt. Sie können nicht durch den Benutzerbereich erstellt oder signalisiert werden. Daher bedeutet dies, dass eine SyncFence immer fortschritte macht.
SyncFence kommt in der Regel in einer von zwei Sorten. "Präsentationszäune" verweisen auf einen SyncFence-Vorgang, wenn das Schreiben in einen Puffer abgeschlossen ist. "Lassen Sie Zäune los" und verweisen Sie dann darauf, wenn der Lesevorgang eines Puffers abgeschlossen ist.
Beispielsweise kann ein GPU-Rendering in einem Framebuffer einen Synchronisierungszaun generieren, z. B. ein EGLSync- oder VkFence-Objekt, das beim Rendern signalisiert wird. Sobald die Zaunsignale signalisiert werden, kann der Sicherungsspeicher für den Framebuffer sicher ausgelesen werden, z. B. für die Anzeige oder für die Mediencodierung. Dies wird als "Präsentationszaun" bezeichnet.
android.media.ImageWriter
In ähnlicher Weise ist es möglich, dass ein android.media.Image
von einem zurückgegebenen ImageWriter#dequeueInputImage()
Benutzer bereits über einen Image#getFence() fence
Satz verfügt. Dies wäre das, was entweder als "Veröffentlichungszaun" oder "Acqurie-Zaun" bezeichnet wird, und gibt den Zaun an, auf den der Autor warten muss, bevor er in den zugrunde liegenden Puffer schreibt. Im Falle von ImageWriter erfolgt dies automatisch, wenn z. B Image#getPlanes()
. aufgerufen wird. Wenn Sie es jedoch verwenden Image#getHardwareBuffer()
, liegt es in der Verantwortung des Aufrufers, sicherzustellen, dass der Freigabezaun vor dem Schreiben in den Puffer signalisiert wurde.
Java-Dokumentation für android.hardware.SyncFence
.
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.
Felder
SignalTimeInvalid |
Ungültige Signalzeit. |
SignalTimePending |
Eine ausstehende Signalzeit. |
Eigenschaften
Class |
Gibt die Laufzeitklasse dieses Werts |
Creator |
Eine SyncFence stellt einen Synchronisierungsgrundtyp dar, der signalisiert, wenn Hardwareeinheiten die Arbeit an einer bestimmten Ressource abgeschlossen haben. |
Handle |
Das Handle für die zugrunde liegende Android-Instanz. (Geerbt von Object) |
IsValid |
Überprüft, ob das SyncFile-Objekt gültig ist. |
JniIdentityHashCode |
Eine SyncFence stellt einen Synchronisierungsgrundtyp dar, der signalisiert, wenn Hardwareeinheiten die Arbeit an einer bestimmten Ressource abgeschlossen haben. (Geerbt von Object) |
JniPeerMembers |
Eine SyncFence stellt einen Synchronisierungsgrundtyp dar, der signalisiert, wenn Hardwareeinheiten die Arbeit an einer bestimmten Ressource abgeschlossen haben. |
PeerReference |
Eine SyncFence stellt einen Synchronisierungsgrundtyp dar, der signalisiert, wenn Hardwareeinheiten die Arbeit an einer bestimmten Ressource abgeschlossen haben. (Geerbt von Object) |
SignalTime |
Gibt die Zeit in Nanosekunden zurück, die der Zaun in der CLOCK_MONOTONIC Zeitdomäne signalisiert. |
ThresholdClass |
Diese API unterstützt die Mono für Android-Infrastruktur und ist nicht für die direkte Verwendung aus Ihrem Code vorgesehen. (Geerbt von Object) |
ThresholdType |
Diese API unterstützt die Mono für Android-Infrastruktur und ist nicht für die direkte Verwendung aus Ihrem Code vorgesehen. (Geerbt von Object) |
Methoden
Await(Duration) |
Wartet auf ein SyncFence-Signal bis zur Timeoutdauer. |
AwaitForever() |
Wartet für immer auf ein SyncFence-Signal. |
Clone() |
Erstellt und gibt eine Kopie dieses Objekts zurück. (Geerbt von Object) |
Close() |
Schließen Sie syncFence. |
DescribeContents() |
Eine SyncFence stellt einen Synchronisierungsgrundtyp dar, der signalisiert, wenn Hardwareeinheiten die Arbeit an einer bestimmten Ressource abgeschlossen haben. |
Dispose() |
Eine SyncFence stellt einen Synchronisierungsgrundtyp dar, der signalisiert, wenn Hardwareeinheiten die Arbeit an einer bestimmten Ressource abgeschlossen haben. (Geerbt von Object) |
Dispose(Boolean) |
Eine SyncFence stellt einen Synchronisierungsgrundtyp dar, der signalisiert, wenn Hardwareeinheiten die Arbeit an einer bestimmten Ressource abgeschlossen haben. (Geerbt von Object) |
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) |
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>() |
Eine SyncFence stellt einen Synchronisierungsgrundtyp dar, der signalisiert, wenn Hardwareeinheiten die Arbeit an einer bestimmten Ressource abgeschlossen haben. (Geerbt von Object) |
ToString() |
Gibt eine Zeichenfolgendarstellung des Objekts zurück. (Geerbt von Object) |
UnregisterFromRuntime() |
Eine SyncFence stellt einen Synchronisierungsgrundtyp dar, der signalisiert, wenn Hardwareeinheiten die Arbeit an einer bestimmten Ressource abgeschlossen haben. (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) |
WriteToParcel(Parcel, ParcelableWriteFlags) |
Flachen Sie dieses Objekt in ein Paket. |
Explizite Schnittstellenimplementierungen
IJavaPeerable.Disposed() |
Eine SyncFence stellt einen Synchronisierungsgrundtyp dar, der signalisiert, wenn Hardwareeinheiten die Arbeit an einer bestimmten Ressource abgeschlossen haben. (Geerbt von Object) |
IJavaPeerable.DisposeUnlessReferenced() |
Eine SyncFence stellt einen Synchronisierungsgrundtyp dar, der signalisiert, wenn Hardwareeinheiten die Arbeit an einer bestimmten Ressource abgeschlossen haben. (Geerbt von Object) |
IJavaPeerable.Finalized() |
Eine SyncFence stellt einen Synchronisierungsgrundtyp dar, der signalisiert, wenn Hardwareeinheiten die Arbeit an einer bestimmten Ressource abgeschlossen haben. (Geerbt von Object) |
IJavaPeerable.JniManagedPeerState |
Eine SyncFence stellt einen Synchronisierungsgrundtyp dar, der signalisiert, wenn Hardwareeinheiten die Arbeit an einer bestimmten Ressource abgeschlossen haben. (Geerbt von Object) |
IJavaPeerable.SetJniIdentityHashCode(Int32) |
Eine SyncFence stellt einen Synchronisierungsgrundtyp dar, der signalisiert, wenn Hardwareeinheiten die Arbeit an einer bestimmten Ressource abgeschlossen haben. (Geerbt von Object) |
IJavaPeerable.SetJniManagedPeerState(JniManagedPeerStates) |
Eine SyncFence stellt einen Synchronisierungsgrundtyp dar, der signalisiert, wenn Hardwareeinheiten die Arbeit an einer bestimmten Ressource abgeschlossen haben. (Geerbt von Object) |
IJavaPeerable.SetPeerReference(JniObjectReference) |
Eine SyncFence stellt einen Synchronisierungsgrundtyp dar, der signalisiert, wenn Hardwareeinheiten die Arbeit an einer bestimmten Ressource abgeschlossen haben. (Geerbt von Object) |
Erweiterungsmethoden
JavaCast<TResult>(IJavaObject) |
Führt eine android-laufzeitgecheckte Typkonvertierung aus. |
JavaCast<TResult>(IJavaObject) |
Eine SyncFence stellt einen Synchronisierungsgrundtyp dar, der signalisiert, wenn Hardwareeinheiten die Arbeit an einer bestimmten Ressource abgeschlossen haben. |
GetJniTypeName(IJavaPeerable) |
Eine SyncFence stellt einen Synchronisierungsgrundtyp dar, der signalisiert, wenn Hardwareeinheiten die Arbeit an einer bestimmten Ressource abgeschlossen haben. |