attributo context_handle_serialize
L'attributo ACF [context_handle_serialize] garantisce che un handle di contesto venga sempre serializzato, indipendentemente dal comportamento predefinito dell'applicazione.
typedef [context_handle_serialize [ , type-acf-attribute-list ] ] context-handle-type;
[context_handle_serialize [, function-acf-attribute-list ] ] function-name( );
function-name(
[context_handle_serialize [ , parameter-acf-attribute-list ] ] param-name );
Parametri
-
type-acf-attribute-list
-
Qualsiasi altro attributo ACF applicabile al tipo.
-
context-handle-type
-
Identificatore che specifica il tipo di handle di contesto, come definito in una dichiarazione typedef . Questo è il tipo che riceve l'attributo [context_handle_serialize] nel file IDL.
-
function-acf-attribute-list
-
Eventuali attributi ACF aggiuntivi che si applicano alla funzione.
-
function-name
-
Nome della funzione come definito nel file IDL.
-
parameter-acf-attribute-list
-
Qualsiasi altro attributo ACF che si applica al parametro .
-
param-name
-
Nome del parametro definito nel file IDL.
Commenti
L'attributo [context_handle_serialize] identifica un handle di associazione che gestisce informazioni sul contesto o sullo stato nel server tra chiamate di routine remote. L'attributo può essere visualizzato come attributo di tipo typedef IDL, come attributo di tipo restituito dalla funzione o come attributo di parametro.
Per impostazione predefinita, le chiamate sugli handle di contesto vengono serializzate, ma un'applicazione può chiamare RpcSsDontSerializeContext per eseguire l'override di questo comportamento predefinito. L'uso dell'attributo [context_handle_serialize] in un file ACF garantisce che le chiamate a questo handle di contesto specifico vengano serializzate, anche se l'applicazione chiamante ha eseguito l'override della serializzazione predefinita. Una routine di rundown del contesto è facoltativa.
Questo attributo è disponibile in MIDL versione 5.0.
Windows Server 2003 e Windows XP o versioni successive: Una singola interfaccia può contenere handle di contesto serializzati e non serializzati, consentendo a un metodo su un'interfaccia di accedere esclusivamente a un handle di contesto (serializzato), mentre altri metodi accedono a tale handle di contesto in modalità condivisa (nonrializzato). Queste funzionalità di accesso sono paragonabili ai meccanismi di blocco di lettura/scrittura; i metodi che usano un handle di contesto serializzato sono utenti esclusivi (writer), mentre i metodi che usano un handle di contesto nonrializzato sono utenti condivisi (lettori). I metodi che eliminano o modificano lo stato di un handle di contesto devono essere serializzati. I metodi che non modificano lo stato di un handle di contesto, ad esempio i metodi che semplicemente leggono da un handle di contesto, possono essere nonrializzati. Si noti che i metodi di creazione vengono serializzati in modo implicito.
Esempi
typedef [context_handle_serialize] PCONTEXT_HANDLE_TYPE;
HRESULT RemoteFunc([context_handle_serialize] pCxHandle);
Vedere anche