Dizi için koleksiyon ifadesini kullanma (IDE0300)

Özellik Değer
Kural Kimliği IDE0300
Başlık Dizi için koleksiyon ifadesini kullanma
Kategori Stil
Alt kategori Dil kuralları (ifade düzeyi tercihleri)
Geçerli diller C# 12+
Seçenekler dotnet_style_prefer_collection_expression

Genel bakış

Bu kural, bir diziyi başlatmak için koleksiyon ifadesinin kullanabildiği yerleri işaretler. Örneğin, bu kural , new[] { ... }ve C[] c = { ... } gibi new C[] { ... }kodları koleksiyon ifade formuna ([...] ) basitleştirmeyi sunar.

Seçenekler

Seçenekler, kuralın zorlamasını istediğiniz davranışı belirtir. Seçenekleri yapılandırma hakkında bilgi için bkz . Seçenek biçimi.

dotnet_style_prefer_collection_expression

Özellik Değer Açıklama
Seçenek adı dotnet_style_prefer_collection_expression
Seçenek değerleri true | when_types_exactly_match Koleksiyon ifadelerini yalnızca türler tam olarak eşleştiğinde kullanmayı tercih eder, örneğin. int[] i = new int[] { 1, 2, 3 };
when_types_loosely_match
(.NET 9 ve sonraki sürümleri)*
Türler gevşek bir şekilde eşleştiğinde bile koleksiyon ifadelerini kullanmayı tercih edin, örneğin. IEnumerable<int> i = new int[] { 1, 2, 3 }; Hedeflenen türün sağ taraftaki türle eşleşmesi veya şu türlerden biri olması gerekir: IEnumerable<T>, ICollection<T>, IList<T>, IReadOnlyCollection<T>, . IReadOnlyList<T>
false | never Kuralı devre dışı bırakır.
Varsayılan seçenek değeri true .NET 8'de
when_types_loosely_match .NET 9 ve sonraki sürümlerde

*Bu seçenek kullanıldığında kod düzeltmesi kodunuzun semantiğini değiştirebilir. Örneğin, varsa IEnumerable<int> x = new int[] { 1, 2, 3 };, özgün kodda bir dizi oluşturulur. Ancak yeni kodda ()IEnumerable<int> x = [1, 2, 3]; bunun yerine derleyici tarafından sentezlenen bir iç tür oluşturulur. Bir çek veya yayın kullanıyorsanız is bu farkı gözlemleyebilirsiniz.

Örnek

// Code with violations.
int[] i = new int[] { 1, 2, 3 };
IEnumerable<int> j = new int[] { 1, 2, 3 };

// Fixed code.
int[] i = [1, 2, 3];
IEnumerable<int> j = [1, 2, 3];

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 IDE0300
// The code that's violating the rule is on this line.
#pragma warning restore IDE0300

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.IDE0300.severity = none

Kod stili kuralların tümünü devre dışı bırakmak için, kategorinin Stylenoneönem derecesini yapılandırma dosyasında olarak ayarlayın.

[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-Style.severity = none

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

Ayrıca bkz.