Verwalten asynchroner Vorgänge
[Ab Windows 8 und Windows Server 2012 wird der Dienst für virtuelle Datenträger durch die Windows Storage Management-API ersetzt.]
Im folgenden Codebeispiel wird veranschaulicht, wie ein Aufrufer mit einem asynchronen Objekt arbeitet. Hier ruft die SynchronCreateLun-Funktion die asynchrone IVdsSubSystem::CreateLun-Methode unter Verwendung der angegebenen Parameter auf. Die Funktion wartet auf das asynchrone Objekt, bis der asynchrone Aufruf der CreateLun-Methode abgeschlossen ist. Wenn die IVdsAsync::Wait-Methode zurückgibt, ruft SynchronousCreateLun die IVdsLun-Schnittstelle für die neu erstellte LUN ab und gibt sie als out-Argument zurück.
//
// 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;
}
Zugehörige Themen