CA2001 : Évitez d'appeler des méthodes susceptibles de poser des problèmes
TypeName |
AvoidCallingProblematicMethods |
CheckId |
CA2001 |
Catégorie |
Microsoft.Reliability |
Modification avec rupture |
Modification sans rupture |
Cause
Un membre appelle une méthode potentiellement dangereuse ou problématique.
Description de la règle
Évitez de faire des appels de méthode inutiles et potentiellement dangereux.
Une violation de cette règle se déclenche lorsqu'un membre appelle l'une des méthodes suivantes.
Méthode |
Description |
---|---|
L'appel de GC.Collect peut affecter de manière significative les performances des applications et est rarement nécessaire. Pour plus d'informations, consultez l'entrée de blog Les petits morceaux de performance de Rico Mariani sur MSDN. |
|
Thread.Suspend et Thread.Resume ont été déconseillées à cause de leur comportement imprévisible. Utilisez d'autres classes dans l'espace de noms System.Threading, telles que Monitor, [T:System.Threading.Mutex,] Mutex, et Semaphore, pour synchroniser les threads ou protéger les ressources. |
|
La méthode DangerousGetHandle introduit un risque en matière de sécurité car elle peut retourner un handle qui n'est pas valide. Consultez les méthodes DangerousAddRef et DangerousRelease pour plus d'informations sur l'utilisation de la méthode DangerousGetHandle de manière sûre. |
|
Ces méthodes peuvent charger des assemblys à partir d'emplacements inattendus. Par exemple, consultez les publications du blog .NET CLR Notes de Suzanne Cook LoadFile vs. LoadFrom et Choosing a Binding Context sur le site Web MSDN pour plus d'informations sur les méthodes qui chargent des assemblys. |
|
CoSetProxyBlanket (Ole32) CoInitializeSecurity (Ole32) |
Lorsque le code utilisateur commence à s'exécuter dans un processus managé, il est trop tard pour appeler CoSetProxyBlanket de manière fiable. CLR (Common Language Runtime) effectue les actions d'initialisation qui peuvent empêcher les utilisateurs P/Invoke de réussir. Si vous devez appeler CoSetProxyBlanket pour une application managée, nous recommandons que vous démarriez le processus à l'aide d'un fichier exécutable de code natif (C++), appelez CoSetProxyBlanket en code natif, puis démarrez votre application de code managé dans le processus. (Assurez-vous de spécifier un numéro de version du runtime.) |
Comment corriger les violations
Pour résoudre une violation de cette règle, supprimez ou remplacez l'appel à la méthode dangereuse ou problématique.
Quand supprimer les avertissements
Vous ne devez supprimer des messages de cette règle que lorsqu'il n'existe aucune alternative à la méthode problématique.