Administración de operaciones asincrónicas
[A partir de Windows 8 y Windows Server 2012, el servicio de disco virtual se sustituye por la API de administración de almacenamiento de Windows.]
En el ejemplo de código siguiente se muestra cómo funciona un llamador con un objeto asincrónico. Aquí, la función SynchronousCreateLun llama al método asincrónico IVdsSubSystem::CreateLun mediante los parámetros especificados. La función esperará al objeto asincrónico para que finalice la llamada asincrónica al método CreateLun . Cuando se devuelve el método IVdsAsync::Wait , SynchronousCreateLun obtiene la interfaz IVdsLun para el LUN recién creado y lo devuelve como 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;
}
Temas relacionados