Catatan
Akses ke halaman ini memerlukan otorisasi. Anda dapat mencoba masuk atau mengubah direktori.
Akses ke halaman ini memerlukan otorisasi. Anda dapat mencoba mengubah direktori.
| Properti | Nilai |
|---|---|
| ID Aturan | CA2252 |
| Judul | Ikut serta untuk mempratinjau fitur sebelum menggunakannya |
| Golongan | Penggunaan |
| Perbaikan bersifat disruptif atau non-disruptif | Non-disruptif |
| Diaktifkan secara default di .NET 10 | Sebagai kesalahan |
Penyebab
Klien menggunakan API atau jenis pratinjau di rakitan mereka tanpa secara eksplisit memilih baik secara lokal atau di tingkat modul atau rakitan.
Deskripsi aturan
Saat API atau rakitan yang dilengkapi dengan atribut RequiresPreviewFeaturesAttribute digunakan, aturan ini memeriksa apakah situs panggilan telah memilih untuk mempratinjau fitur. Situs panggilan telah memilih untuk mempratinjau fitur jika salah satu hal berikut ini berlaku:
- Berada dalam cakupan anotasi
RequiresPreviewFeaturesAttribute. - Merupakan bagian dari rakitan atau modul yang telah memilih untuk mempratinjau fitur.
Gambar berikut menunjukkan contoh diagnostik CA2252.
Di sini, Lib adalah jenis pratinjau yang dibangun dalam metode Main.
Main itu sendiri tidak dianotasi sebagai metode pratinjau, sehingga diagnostik diproduksi pada dua panggilan konstruktor di dalam Main.
Cara memperbaiki pelanggaran
Ada dua cara untuk memperbaiki pelanggaran:
Bawa situs panggilan dalam cakupan anotasi dengan menganotasi induknya dengan
RequiresPreviewFeaturesAttribute. Dalam contoh sebelumnya,APreviewMethoddianotasi dengan atributRequiresPreviewFeatures, sehingga penganalisis mengabaikan penggunaan jenis pratinjau di dalamAPreviewMethod. Ini mengikuti bahwa pemanggilAPreviewMethodharus melakukan latihan serupa.Anda juga dapat memilih untuk mempratinjau fitur pada tingkat rakitan atau modul. Ini menunjukkan kepada penganalisis bahwa penggunaan jenis pratinjau di rakitan diinginkan dan, sebagai konsekuensinya, tidak ada kesalahan yang akan dihasilkan oleh aturan ini. Ini adalah cara yang utama untuk menggunakan dependensi pratinjau. Untuk mengaktifkan fitur pratinjau di dalam seluruh rakitan, atur properti EnablePreviewFeatures dalam file
.csproj:
<PropertyGroup>
<EnablePreviewFeatures>true</EnablePreviewFeatures>
</PropertyGroup>
Kapan harus menekan peringatan
Menyembunyikan peringatan dari aturan ini hanya disarankan untuk kasus penggunaan tingkat lanjut di mana diagnostik pada API perlu dinonaktifkan secara eksplisit. Dalam hal ini, Anda harus bersedia mengambil tanggung jawab untuk menandai API pratinjau dengan tepat. Misalnya, pertimbangkan kasus saat jenis yang ada mengimplementasikan antarmuka pratinjau baru. Karena seluruh jenis tidak dapat ditandai sebagai pratinjau (untuk kompatibilitas mundur), diagnostik di sekitar definisi jenis dapat dinonaktifkan secara lokal. Selanjutnya, Anda perlu menandai implementasi antarmuka pratinjau sebagai pratinjau. Sekarang, jenis yang ada dapat digunakan seperti sebelumnya, tetapi panggilan ke metode antarmuka baru akan mendapatkan diagnostik.
System.Private.CoreLib.csproj menggunakan teknik ini untuk mengekspos fitur matematika generik pada jenis numerik seperti Int32, Double, dan Decimal.
Gambar berikut menunjukkan cara menonaktifkan penganalisis CA2252 secara lokal.
Catatan
Anda mungkin melihat peringatan positif palsu dari aturan ini jika semua hal berikut ini berlaku:
- Anda menggunakan Visual Studio 2022 versi 17.5 atau yang lebih baru dengan versi .NET SDK yang lebih lama, yaitu, .NET 6 atau yang lebih lama.
- Anda menggunakan penganalisis dari .NET 6 SDK atau versi paket penganalisis yang lebih lama, seperti Microsoft.CodeAnalysis.FxCopAnalyzers.
Dalam hal ini, aman untuk menekan peringatan positif palsu. Positif palsu disebabkan oleh perubahan yang melanggar dalam pengkompilasi C#. Pertimbangkan untuk menggunakan penganalisis yang lebih baru yang berisi perbaikan untuk peringatan positif palsu. Tingkatkan ke Microsoft.CodeAnalysis.NetAnalyzers versi 7.0.0-preview1.22464.1 atau yang lebih baru atau gunakan penganalisis dari .NET 7 SDK.
Menyembunyikan peringatan
Jika Anda hanya ingin menyembunyikan satu pelanggaran, tambahkan arahan praprosedur ke file sumber Anda untuk dinonaktifkan lalu aktifkan kembali aturannya.
#pragma warning disable CA2252
// The code that's violating the rule is on this line.
#pragma warning restore CA2252
Untuk menonaktifkan aturan untuk file, folder, atau proyek, atur tingkat keparahannya ke none dalam file konfigurasi.
[*.{cs,vb}]
dotnet_diagnostic.CA2252.severity = none
Untuk menonaktifkan seluruh kategori aturan ini, atur tingkat keparahan untuk kategori ke none dalam file konfigurasi.
[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-Usage.severity = none
Untuk informasi selengkapnya, lihat Cara menyembunyikan peringatan analisis kode.