다음을 통해 공유


StorageLibraryChangeTrackerOptions.TrackChangeDetails 속성

정의

시스템에서 각 개별 변경 내용을 추적할지 또는 지정된 변경 추적자에 대한 마지막 변경 ID만 추적할지 확인하는 데 사용됩니다.

public:
 property bool TrackChangeDetails { bool get(); void set(bool value); };
bool TrackChangeDetails();

void TrackChangeDetails(bool value);
public bool TrackChangeDetails { get; set; }
var boolean = storageLibraryChangeTrackerOptions.trackChangeDetails;
storageLibraryChangeTrackerOptions.trackChangeDetails = boolean;
Public Property TrackChangeDetails As Boolean

속성 값

Boolean

bool

변경 추적기가 모든 변경 세부 정보 또는 마지막 변경 ID만 추적해야 하는지 여부를 결정하는 부울 값입니다. 설정하거나 수정하지 않으면 기본값은 true입니다.

예제

// applications are expected to persist the previous value
UINT64 appsLastPersistedChangeId = StorageLibraryLastChangeId::Unknown();
StorageFolder folder = StorageFolder::GetFolderFromPathAsync(L"my folder path").get();

StorageLibraryChangeTracker tracker = folder.TryGetChangeTracker();
if (tracker != nullptr)
{
StorageLibraryChangeTrackerOptions ops;
ops.TrackChangeDetails(false);
tracker.Enable(ops);

StorageLibraryChangeReader reader = tracker.GetChangeReader();
if (reader != nullptr)
{
    UINT32 changeId = reader.GetLastChangeId();
    if ((changeId == StorageLibraryLastChangeId::Unknown())
    {
        ScanFolderSlow();
    }
    else if (changeId == 0)
    {
        // no changes in the storage folder yet, OR nothing has changed
        ProcessNormalApplicationStartup();
    }
    else if (changeId != appsLastPersistedChangeId)
    {
        // There have been new changes since we’ve last ran, process them
        appsLastPersistedChangeId = changeId;
        ScanFolderForChanges();
    }
    else
    {
        // changeId and our last persisted change id match, also normal application startup
        ProcessNormalApplicationStartup();
    }
}
}

설명

TrackChangeDetails는 모든 변경 추적기에서 기본적으로 true입니다. 애플리케이션이 마지막 변경 ID에만 관련된 경우 시스템 스토리지에 저장하기 위해 StorageLibraryChangeTracker::EnableWithOptions에 전달될 때 이를 false로 설정할 수 있으며 각 개별 변경 내용에 대한 세부 정보는 포함하지 않습니다.

적용 대상

추가 정보