Partager via


Avertissements liés aux performances

Les avertissements liés aux performances prennent en charge des bibliothèques et des applications haute performance.

Dans cette section

Règle

Description

CA1800 : N'effectuez pas de cast inutilement

Les casts en doublon font baisser les performances, surtout lorsque les casts sont exécutés au sein d'instructions d'itération compactes.

CA1801 : Passez en revue les paramètres inutilisés

Une signature de méthode inclut un paramètre qui n'est pas utilisé dans le corps de la méthode.

CA1802 : Utilisez des littéraux lorsque nécessaire

Un champ est déclaré statique et en lecture seule (Shared et ReadOnly en Visual Basic), et est initialisé avec une valeur qui est calculable à la compilation. La valeur assignée au champ ciblé étant calculable à la compilation, remplacez la déclaration par un champ const (Const en Visual Basic) afin que la valeur soit calculée à la compilation plutôt qu'à l'exécution.

CA1804 : Supprimez les variables locales inutilisées

Les variables locales inutilisées et les assignations inutiles augmentent la taille d'un assembly et font baisser les performances.

CA1806 : Ne pas ignorer les résultats de méthode

Un nouvel objet est créé mais jamais utilisé, ou une méthode qui crée et retourne une nouvelle chaîne est appelée et la nouvelle chaîne n'est jamais utilisée, ou une méthode COM (Component Object Model) ou P/Invoke retourne un code HRESULT ou d'erreur qui n'est jamais utilisé.

CA1809 : Évitez le surplus de variables locales

Une méthode d'optimisation des performances courante consiste à stocker une valeur dans un registre de processeur au lieu de la mémoire ; cette méthode est appelée « enregistrement de la valeur ». Pour augmenter les chances d'enregistrement de toutes les variables locales, limitez le nombre de variables locales à 64.

CA1810 : Initialisez les champs statiques de type référence en ligne

Lorsqu'un type déclare un constructeur statique explicite, le compilateur juste-à-temps (JIT, Just-In-Time) ajoute une vérification à chacun des méthodes statiques et constructeurs d'instances du type afin de garantir que le constructeur statique a été appelé précédemment. Les vérifications des constructeurs statiques peuvent diminuer les performances.

CA1811 : Évitez le recours à du code privé non appelé

Un membre privé ou interne (de niveau assembly) n'a pas d'appelants dans l'assembly, et n'est appelé ni par le Common Language Runtime, ni par un délégué.

CA1812 : Évitez les classes internes non instanciées

Une instance d'un type de niveau assembly n'est pas créée par le code au sein de l'assembly.

CA1813 : Évitez les attributs unsealed

La bibliothèque de classes du .NET Framework fournit des méthodes pour récupérer des attributs personnalisés. Par défaut, ces méthodes recherchent la hiérarchie d'héritage des attributs. Le fait de sceller l'attribut élimine la recherche dans la hiérarchie d'héritage et peut améliorer les performances.

CA1814 : Utilisez des tableaux en escalier à la place de tableaux multidimensionnels

Un tableau en escalier est un tableau dont les éléments sont des tableaux. Les tableaux qui composent les éléments peuvent être de différentes tailles, ce qui peut entraîner un gaspillage d'espace plus modéré pour certains groupes de données.

CA1815 : Remplacez Equals et l'opérateur égal à dans les types valeur

Pour les types valeur, l'implémentation héritée de Equals utilise la bibliothèque Reflection et compare le contenu de tous les champs. Le processus de réflexion sollicite fortement les ressources informatiques et la comparaison de chaque champ à la recherche d'une égalité peut s'avérer inutile. Si des utilisateurs sont susceptibles de comparer ou de trier des instances, ou de les utiliser en tant que clés de table de hachage, votre type valeur doit implémenter Equals.

CA1816 : Appeler GC.SuppressFinalize correctement

Une méthode qui est une implémentation de Dispose n'appelle pas GC.SuppressFinalize, ou une méthode qui n'est pas une implémentation de Dispose appelle GC.SuppressFinalize, ou une méthode appelle GC.SuppressFinalize et passe un élément autre que celui-ci (Me en Visual Basic).

CA1819 : Les propriétés ne doivent pas retourner des tableaux

Les tableaux retournés par les propriétés ne sont pas protégés en écriture, même si la propriété est en lecture seule. Pour protéger le tableau de toute falsification, la propriété doit retourner une copie du tableau. En général, les utilisateurs ne comprennent l'incidence négative en matière de performances de l'appel à une telle propriété.

CA1820 : Vérifiez la présence de chaînes vides par la longueur de chaîne

La comparaison de chaînes à l'aide de la propriété String.Length ou de la méthode String.IsNullOrEmpty est nettement plus rapide que l'utilisation d'Equals.

CA1821 : Supprimer les finaliseurs vides

Évitez autant que possible d'utiliser des finaliseurs en raison de la surcharge supplémentaire des performances impliquée dans le suivi de la durée de vie de l'objet. Un finaliseur vide entraîne une charge supplémentaire sans aucun avantage.

CA1822 : Marquez les membres comme static

Les membres qui n'accèdent pas aux données d'instance ou n'appellent pas de méthodes d'instance peuvent être marquées comme static (Shared en Visual Basic). Une fois que les méthodes ont été marquées comme static, le compilateur émet des sites d'appel non virtuels vers ces membres. Cette opération se traduit par un gain de performances mesurable pour le code dépendant des performances.

CA1823 : Évitez les champs privés inutilisés

Des champs privés qui ne sont pas accessibles dans l'assembly ont été détectés.

CA1824 : Marquer les assemblys avec NeutralResourcesLanguageAttribute

L'attribut NeutralResourcesLanguage informe le ResourceManager de la langue qui a été utilisée pour afficher les ressources d'une culture neutre d'un assembly. Cela permet d'améliorer les performances de recherche de la première ressource chargée et de réduire votre jeu de travail.