CA1002: Genel listeleri gösterme

Özellik Değer
Kural Kimliği CA1002
Başlık Genel listeleri gösterme
Kategori Tasarım
Hataya neden olan veya bozulmayan düzeltme Yeni
.NET 8'de varsayılan olarak etkin Hayır

Neden

Tür, bir tür olan, bir System.Collections.Generic.List<T> tür döndüren List<T> veya imzası parametre içeren dışarıdan görünür bir List<T> üye içerir.

Varsayılan olarak, bu kural yalnızca dışarıdan görünen türlere bakar, ancak bu yapılandırılabilir.

Kural açıklaması

System.Collections.Generic.List<T> devralma için değil performans için tasarlanmış genel bir koleksiyondur. List<T> devralınan bir sınıfın davranışını değiştirmeyi kolaylaştıran sanal üyeler içermez. Aşağıdaki genel koleksiyonlar devralma için tasarlanmıştır ve yerine List<T>kullanıma sunulmalıdır.

İhlalleri düzeltme

Bu kuralın ihlalini düzeltmek için türü devralma için tasarlanmış genel koleksiyonlardan biriyle değiştirin System.Collections.Generic.List<T> .

Uyarıların ne zaman bastırılması gerekiyor?

Bu uyarıyı oluşturan derlemenin yeniden kullanılabilir bir kitaplık olması amaçlanmadığı sürece bu kuraldan gelen bir uyarıyı bastırmayın. Örneğin, genel listelerin kullanımından bir performans avantajının elde edildiği performans ayarlı bir uygulamada bu uyarıyı gizlemeniz güvenli olacaktır.

Uyarıyı gizleme

Yalnızca tek bir ihlali engellemek istiyorsanız, kuralı devre dışı bırakmak ve sonra yeniden etkinleştirmek için kaynak dosyanıza ön işlemci yönergeleri ekleyin.

#pragma warning disable CA1002
// The code that's violating the rule is on this line.
#pragma warning restore CA1002

Bir dosya, klasör veya projenin kuralını devre dışı bırakmak için, yapılandırma dosyasındaki önem derecesini noneolarak ayarlayın.

[*.{cs,vb}]
dotnet_diagnostic.CA1002.severity = none

Daha fazla bilgi için bkz . Kod analizi uyarılarını gizleme.

Çözümlemek için kod yapılandırma

Bu kuralın kod tabanınızın hangi bölümlerinde çalıştırılacaklarını yapılandırmak için aşağıdaki seçeneği kullanın.

Bu seçeneği yalnızca bu kural, geçerli olduğu tüm kurallar veya bu kategorideki (Tasarım) tüm kurallar için yapılandırabilirsiniz. Daha fazla bilgi için bkz . Kod kalitesi kuralı yapılandırma seçenekleri.

Belirli API yüzeylerini ekleme

Bu kuralın üzerinde çalıştırılacak kod tabanınızın hangi bölümlerini erişilebilirliklerine göre yapılandırabilirsiniz. Örneğin, kuralın yalnızca genel olmayan API yüzeyinde çalıştırılması gerektiğini belirtmek için projenizdeki bir .editorconfig dosyasına aşağıdaki anahtar-değer çiftini ekleyin:

dotnet_code_quality.CAXXXX.api_surface = private, internal

CA1005: Genel türlerde aşırı parametrelerden kaçının

CA1010: Koleksiyonlar genel arabirim uygulamalıdır

CA1000: Genel türlerde statik üyeleri belirtme

CA1003: Genel olay işleyici örnekleri kullan

Ayrıca bkz.

Genel Türler