Gerenciando operações assíncronas
[Começando com Windows 8 e Windows Server 2012, o Serviço de Disco Virtual é substituído pela API de Gerenciamento de Armazenamento do Windows.]
O exemplo de código a seguir demonstra como um chamador funciona com um objeto assíncrono. Aqui, a função SynchronousCreateLun chama o método IVdsSubSystem::CreateLun assíncrono usando os parâmetros especificados. A função aguardará o objeto assíncrono para que a chamada de método CreateLun assíncrona seja concluída. Quando o método IVdsAsync::Wait retorna, SynchronousCreateLun obtém a interface IVdsLun para o LUN recém-criado e o retorna como um argumento out.
//
// Simple macro to release non-null interfaces.
//
#include <windows.h>
#include "vds.h"
#include <stdio.h>
#define _SafeRelease(x) {if (NULL != x) { x->Release(); x = NULL; } }
HRESULT SynchronousCreateLun(
IVdsSubSystem *pSubsystem,
VDS_LUN_TYPE type,
ULONGLONG ullSize,
VDS_OBJECT_ID *pDriveIdArray,
LONG lNumberOfDrives,
LPWSTR pwszUnmaskingList,
VDS_HINTS *pHints,
IVdsLun **ppLun)
{
HRESULT hResult = S_OK;
HRESULT hResult2 = S_OK;
IVdsAsync *pAsync = NULL;
VDS_ASYNC_OUTPUT AsyncOut;
IUnknown* pUnknown = NULL;
ZeroMemory( &AsyncOut, sizeof(VDS_ASYNC_OUTPUT));
hResult = pSubsystem->CreateLun(
type,
ullSize,
pDriveIdArray,
lNumberOfDrives,
pwszUnmaskingList,
pHints,
&pAsync);
if (SUCCEEDED(hResult) && (!pAsync)) {
hResult = E_UNEXPECTED; // Errant provider, returned S_OK
// with a NULL pointer.
}
if (SUCCEEDED(hResult)) {
// Wait until the Async is done.
hResult2 = pAsync->Wait( &hResult, &AsyncOut);
if (SUCCEEDED(hResult) && FAILED(hResult2)) {
hResult = hResult2;
}
}
if (SUCCEEDED(hResult) && (VDS_ASYNCOUT_CREATELUN != AsyncOut.type)) {
hResult = E_UNEXPECTED; // Errant provider, returned S_OK
// with an unexpected type.
}
if (SUCCEEDED(hResult)) {
pUnknown = AsyncOut.cl.pLunUnk;
if (!pUnknown) {
hResult = E_UNEXPECTED; // Errant provider, returned
// S_OK with a NULL pointer.
}
}
if (SUCCEEDED(hResult)) {
hResult = pUnknown->QueryInterface(IID_IVdsLun, (void **)ppLun);
}
_SafeRelease(pAsync);
_SafeRelease(pUnknown);
return hResult;
}
Tópicos relacionados