IWMDMDevice2::GetStorage 方法 (mswmdm.h)
GetStorage 方法會搜尋根記憶體的立即子系,以尋找具有指定名稱的記憶體。
語法
HRESULT GetStorage(
[in] LPCWSTR pszStorageName,
[out] IWMDMStorage **ppStorage
);
參數
[in] pszStorageName
指定要尋找之記憶體名稱的 Null 終止字串指標。 此參數不支援通配符。
[out] ppStorage
pszStorageName 參數所指定之記憶體的 IWMDMStorage 介面指標。 呼叫端必須在完成此介面時釋放此介面。
傳回值
方法會傳回 HRESULT。 Windows Media 裝置管理員 中的所有介面方法都可以傳回下列任何一種錯誤碼類別:
- 標準 COM 錯誤碼
- 轉換成 HRESULT 值的 Windows 錯誤碼
- Windows Media 裝置管理員 錯誤碼
備註
此函式不是遞迴的;它只會搜尋裝置根記憶體的立即子系。 如需此函式的遞歸搜尋版本,請使用 IWMDMDevice3::FindStorage。
範例
下列 C++ 函式會以遞歸方式搜尋記憶體。 它會使用 GetStorage 來搜尋立即子系;如果找不到要求的記憶體,則會迴圈查看所有子系,然後以遞歸方式搜尋資料夾。
HRESULT myFindStorageRecursively(LPCWSTR storageName, IWMDMStorage* pCurrentStorage, IWMDMStorage** ppFoundStorage)
{
HRESULT hr = S_OK;
// Start with a quick check of all storages inside the storage.
// If we found it, stop now and return.
CComQIPtr<IWMDMStorage2> pStorage2(pCurrentStorage);
hr = pStorage2->GetStorage(storageName, ppFoundStorage);
if (*ppFoundStorage != NULL)
return hr;
//
// Otherwise, enumerate through and dive into all child folders.
//
// First get enumerator.
CComPtr<IWMDMEnumStorage> pEnumStorage;
hr = pCurrentStorage->EnumStorage(&pEnumStorage);
if (hr != S_OK && pEnumStorage != NULL)
return hr;
// Now enumerate all folders until found the right item, or out of folders.
CComPtr<IWMDMStorage> pThisStorage;
DWORD numRetrieved = 0;
DWORD attr = 0;
while(pEnumStorage->Next(1, &pThisStorage, &numRetrieved) == S_OK)
{
pThisStorage->GetAttributes(&attr, NULL);
if (attr & WMDM_FILE_ATTR_FOLDER)
{
hr = myFindStorageRecursively(storageName, pThisStorage, ppFoundStorage);
if (*ppFoundStorage != NULL)
return hr;
}
pThisStorage.Release();
}
return hr;
}
規格需求
需求 | 值 |
---|---|
目標平台 | Windows |
標頭 | mswmdm.h |
程式庫 | Mssachlp.lib |