Rumah >Java >javaTutorial >Bagaimana untuk Menggantikan Aksara Unikod Tidak Boleh Cetak dengan Berkesan dalam Rentetan Java?
Menggantikan Aksara Unikod Tidak Boleh Cetak dalam Java: Pendekatan Komprehensif
Persoalan yang timbul ialah dengan berkesan menggantikan aksara Unikod yang tidak boleh dicetak dalam Java rentetan. Aksara kawalan ASCII boleh dikendalikan dengan cekap menggunakan regex berikut:
my_string.replaceAll("\p{Cntrl}", "?");
Selain itu, aksara tidak boleh cetak ASCII, termasuk aksara beraksen, boleh digantikan dengan:
my_string.replaceAll("[^\p{Print}]", "?");
Walau bagaimanapun, kedua-duanya pendekatan gagal apabila berurusan dengan rentetan Unicode. Penyelesaian yang mantap diperlukan untuk menangani cabaran ini.
Penyelesaian: Memanfaatkan "p{C}"
Kunci untuk mengendalikan aksara tidak boleh cetak Unicode terletak pada penggunaan regex:
my_string.replaceAll("\p{C}", "?");
regex ini berkesan mengenal pasti dan menggantikan semua Unicode yang tidak boleh dicetak aksara.
Memahami Ungkapan Biasa Unikod
Java.util.regexPattern/String.replaceSemua kelas menyokong sepenuhnya ungkapan biasa Unicode. Pendek kata "p{C}" mewakili aksara kawalan Unikod.
Dengan memanfaatkan pendekatan ini, anda boleh menggantikan aksara tidak boleh cetak dengan cekap dalam rentetan Unikod, memastikan manipulasi rentetan yang konsisten.
Atas ialah kandungan terperinci Bagaimana untuk Menggantikan Aksara Unikod Tidak Boleh Cetak dengan Berkesan dalam Rentetan Java?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!