IHostTaskManager::BeginThreadAffinity, méthode
Avertit l’hôte que le code managé entre dans une période pendant laquelle la tâche actuelle ne doit pas être déplacée vers un autre thread du système d’exploitation.
Syntaxe
HRESULT BeginThreadAffinity ();
Valeur de retour
HRESULT | Description |
---|---|
S_OK | BeginThreadAffinity retourné. |
HOST_E_CLRNOTAVAILABLE | Le Common Language Runtime (CLR) n’a pas été chargé dans un processus ou est dans un état dans lequel il ne peut ni exécuter le code managé ni traiter l’appel avec succès. |
HOST_E_TIMEOUT | L’appel a expiré. |
HOST_E_NOT_OWNER | L’appelant n’est pas propriétaire du verrou. |
HOST_E_ABANDONED | Un événement a été annulé alors qu’un thread ou une fibre bloqué l’attendait. |
E_FAIL | Une défaillance catastrophique inconnue s’est produite. Quand une méthode retourne E_FAIL, le CLR n’est plus utilisable au sein du processus. Les appels suivants aux méthodes d’hébergement renvoient HOST_E_CLRNOTAVAILABLE. |
Notes
Le CLR appelle généralement IHostTaskManager::BeginThreadAffinity
dans le contexte d’un appel à Thread.BeginThreadAffinity. Pour replanifier la tâche actuelle, un appel correspondant à IHostTaskManager::EndThreadAffinity doit d’abord être effectué. Les tâches peuvent être désactivées, mais quand elles sont réactivées, elles doivent être affectées au même thread du système d’exploitation à partir duquel elles ont été désactivées. Les appels imbriqués à BeginThreadAffinity
n’ont aucun effet, car l’appel fait référence à la tâche actuelle.
Spécifications
Plateformes : Consultez Configuration requise.
En-tête : MSCorEE.h
Bibliothèque : incluse en tant que ressource dans MsCorEE.dll
Versions de .NET Framework : Disponible depuis la version 2.0