AnchorEnumerationContext.ReportChanges-Methode
Meldet den Satz von Änderungen, die beim Aufrufen von EnumerateChanges abgerufen wurden.
Namespace: Microsoft.Synchronization.SimpleProviders
Assembly: Microsoft.Synchronization.SimpleProviders (in microsoft.synchronization.simpleproviders.dll)
Syntax
'Declaration
Public Sub ReportChanges ( _
itemChanges As IEnumerable(Of LocalItemChange), _
updatedAnchor As Byte() _
)
'Usage
Dim instance As AnchorEnumerationContext
Dim itemChanges As IEnumerable(Of LocalItemChange)
Dim updatedAnchor As Byte()
instance.ReportChanges(itemChanges, updatedAnchor)
public void ReportChanges (
IEnumerable<LocalItemChange> itemChanges,
byte[] updatedAnchor
)
public:
void ReportChanges (
IEnumerable<LocalItemChange^>^ itemChanges,
array<unsigned char>^ updatedAnchor
)
public void ReportChanges (
IEnumerable<LocalItemChange> itemChanges,
byte[] updatedAnchor
)
public function ReportChanges (
itemChanges : IEnumerable<LocalItemChange>,
updatedAnchor : byte[]
)
Parameter
- itemChanges
Eine Auflistung von LocalItemChange-Objekten, die Metadaten zu Änderungen an Elementen im lokalen Replikat enthalten.
- updatedAnchor
Ein Bytearray, das einen Enumerationsanker darstellt, z. B. einen Timestamp.
Ausnahmen
Ausnahmetyp | Bedingung |
---|---|
ReportItemsAndAutodetectDeletes wurde in der gleichen Sitzung aufgerufen. |
Beispiel
Das folgende Codebeispiel enthält das AnchorEnumerationContext-Objekt, das an die EnumerateChanges-Methode übergeben wird, sowie die ReportChanges-Methode, die für das Context-Objekt aufgerufen wird. In der "Sync101 using Simple Sync Provider"
-Anwendung, die im Sync Framework SDK und in der Code Gallery verfügbar ist, finden Sie diesen Code im Kontext einer vollständigen Anwendung.
public override void EnumerateChanges(byte[] anchor, AnchorEnumerationContext context)
{
List<LocalItemChange> itemChanges = new List<LocalItemChange>();
int startIndex = -1;
if (anchor != null)
{
startIndex = _store.Changes.IndexOfKey(BitConverter.ToUInt64(anchor, 0));
}
for (int i = startIndex + 1; i < _store.Changes.Count; i++)
{
itemChanges.Add(_store.Changes.Values[i]);
}
// If the anchor is corrupt or out of date we could revert back to
// full enumeration mode for this session, and enumerate all items.
// This is done by calling context.ReportItemsAndAutodetectDeletes.
context.ReportChanges(itemChanges, _store.GetAnchor());
}
Public Overrides Sub EnumerateChanges(ByVal anchor As Byte(), ByVal context As AnchorEnumerationContext)
Dim itemChanges As New List(Of LocalItemChange)()
Dim startIndex As Integer = -1
If anchor IsNot Nothing Then
startIndex = _store.Changes.IndexOfKey(BitConverter.ToUInt64(anchor, 0))
End If
For i As Integer = startIndex + 1 To _store.Changes.Count - 1
itemChanges.Add(_store.Changes.Values(i))
Next
' If the anchor is corrupt or out of date we could revert back to
' full enumeration mode for this session, and enumerate all items.
' This is done by calling context.ReportItemsAndAutodetectDeletes.
context.ReportChanges(itemChanges, _store.GetAnchor())
End Sub
Siehe auch
Verweis
AnchorEnumerationContext-Klasse
AnchorEnumerationContext-Member
Microsoft.Synchronization.SimpleProviders-Namespace