Funzione RpcServerInterfaceGroupCreateW (rpcdce.h)
La funzione RpcServerInterfaceGroupCreate crea un gruppo di interfacce server RPC per l'applicazione server. Questo gruppo di interfacce specifica completamente le interfacce, gli endpoint e le proprietà inattive di un'applicazione server RPC. Una volta creato, un gruppo di interfacce può essere attivato e disattivato in base alle esigenze dell'applicazione.
Sintassi
RPC_STATUS RpcServerInterfaceGroupCreateW(
[in] RPC_INTERFACE_TEMPLATEW *Interfaces,
[in] unsigned long NumIfs,
[in] RPC_ENDPOINT_TEMPLATEW *Endpoints,
[in] unsigned long NumEndpoints,
[in] unsigned long IdlePeriod,
[in] RPC_INTERFACE_GROUP_IDLE_CALLBACK_FN IdleCallbackFn,
[in] void *IdleCallbackContext,
[out] PRPC_INTERFACE_GROUP IfGroup
);
Parametri
[in] Interfaces
Puntatore a una matrice di strutture RPC_INTERFACE_TEMPLATE che definiscono le interfacce esposte dal gruppo di interfacce.
[in] NumIfs
Numero di elementi in interfacce .
[in] Endpoints
Puntatore a una matrice di strutture RPC_ENDPOINT_TEMPLATE che definiscono gli endpoint usati dal gruppo di interfacce.
[in] NumEndpoints
Numero di elementi in endpoint .
[in] IdlePeriod
Periodo di tempo in secondi dopo che il gruppo di interfacce diventa inattivo che il runtime RPC deve attendere prima di richiamare il callback inattivo. 0 indica che il callback viene richiamato immediatamente. infinite significa che l'applicazione server non si preoccupa dello stato di inattività del gruppo di interfacce.
[in] IdleCallbackFn
Callback RPC_INTERFACE_GROUP_IDLE_CALLBACK_FN che il runtime RPC richiamerà dopo che il gruppo di interfaccia è inattivo per il periodo di tempo specificato in IdlePeriod. Può essere NULL solo se IdlePeriod è INFINITE.
[in] IdleCallbackContext
Puntatore definito dall'utente da passare al callback inattivo in IdleCallbackFn.
[out] IfGroup
In caso di esito positivo, un puntatore a un buffer RPC_INTERFACE_GROUP che riceve l'handle al gruppo di interfacce appena creato. Se questa funzione ha esito negativo, IfGroup non è definita.
Valore restituito
Valore | Significato |
---|---|
|
Chiamata riuscita. |
Osservazioni
Facoltativamente, un'applicazione server può ricevere una notifica quando un gruppo di interfacce diventa inattiva. Anche se qualsiasi applicazione può sfruttare questa funzionalità, è destinata agli sviluppatori di servizi che vogliono consentire al servizio di arrestarsi.
idlePeriod impedisce al runtime RPC di produrre un numero elevato di notifiche se lo stato di inattività cambia rapidamente e, nel caso di servizi attivati, consente al servizio di evitare l'avvio e l'arresto inutili. Gli sviluppatori devono considerare il costo dell'inizializzazione e dell'arresto del servizio, la frequenza prevista con cui si verificherà una nuova attività e il costo di mantenere il servizio inattivo quando si seleziona questo valore. Un periodo di inattività basso causerà spesso l'avvio e l'arresto del servizio man mano che avviene una nuova attività client, mentre un periodo di inattività elevato causerà l'utilizzo delle risorse da parte del servizio senza eseguire operazioni significative.
Le interfacce in un gruppo di interfaccia possono essere chiamate solo sugli endpoint dello stesso gruppo. Le interfacce che non fanno parte di un gruppo di interfacce non possono essere chiamate sugli endpoint che fanno parte di un gruppo.
L'attività del server RPC non è sempre visibile all'applicazione server. In alcuni casi, la semplice presenza di un client con una connessione aperta al server può mantenerla attiva anche se non sono state inviate chiamate per un lungo periodo di tempo. Le applicazioni server non devono basarsi su alcuna correlazione tra il runtime RPC dichiarando che il gruppo è inattivo e l'ora in cui è stata inviata l'ultima chiamata.
Nota
L'intestazione rpcdce.h definisce RpcServerInterfaceGroupCreate come alias che seleziona automaticamente la versione ANSI o Unicode di questa funzione in base alla definizione della costante del preprocessore UNICODE. La combinazione dell'utilizzo dell'alias indipendente dalla codifica con il codice non indipendente dalla codifica può causare mancate corrispondenze che generano errori di compilazione o di runtime. Per altre informazioni, vedere convenzioni di per i prototipi di funzioni.
Fabbisogno
Requisito | Valore |
---|---|
client minimo supportato | Windows 8 [solo app desktop] |
server minimo supportato | Windows Server 2012 [solo app desktop] |
piattaforma di destinazione | Finestre |
intestazione |
rpcdce.h (include Rpc.h) |
libreria |
Rpcrt4.lib |
dll | Rpcrt4.dll |
Vedere anche
RpcServerInterfaceGroupActivate