本文整理汇总了C#中Snapshot.Find方法的典型用法代码示例。如果您正苦于以下问题:C# Snapshot.Find方法的具体用法?C# Snapshot.Find怎么用?C# Snapshot.Find使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Snapshot
的用法示例。
在下文中一共展示了Snapshot.Find方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: UpdateSnapshot
//.........这里部分代码省略.........
bool nothingToProcess = false;
if (currentTime > LastTimestamp.Time)
{
packets = GetForward(new TimeStamp(currentTime));
}
else if (currentTime < LastTimestamp.Time)
{
packets = GetBackward(new TimeStamp(currentTime));
isBackward = true;
}
else
{
nothingToProcess = true;
}
LastTimestamp = new TimeStamp(currentTime);
if (nothingToProcess && !forceUpdate)
{
return;
}
}
if (AddressRange.Max < AddressRange.Min)
{
return;
}
// Create final list, removing allocations as frees are encountered
if (packets != null)
{
int index = 0;
foreach (var pair in packets)
{
// On a full rebuild, if there's a position specified in
// the snapshot, only go up to that position
if (forceFullRebuild && snapshot.Position > 0)
{
if (index > snapshot.Position)
{
break;
}
}
// TODO: Can allocation and free processing be combined?
// They should be exact opposites of each other
if (pair.Value is Allocation)
{
Allocation allocation = pair.Value as Allocation;
if (!isBackward)
{
MemoryBlock newBlock = snapshot.Add(
allocation, AddressRange.Min, AddressWidth);
}
else
{
snapshot.Remove(allocation.Address);
}
}
else
{
Free free = pair.Value as Free;
if (snapshot.Find(free.Address) != null)
{
MemoryBlock removedBlock = snapshot.Remove(free.Address);
if (removedBlock != null)
{
removedBlock.Allocation.AssociatedFree = free;
free.AssociatedAllocation = removedBlock.Allocation;
}
}
else
{
if (isBackward)
{
MemoryBlock newBlock = snapshot.Add(
free.AssociatedAllocation, AddressRange.Min, AddressWidth);
}
}
}
index++;
}
if (!forceFullRebuild || snapshot.Position == 0)
{
snapshot.Position = Position;
}
}
if (Rebuilt != null)
{
EventArgs e = new EventArgs();
Rebuilt.Invoke(this, e);
}
} //);
}