다음은 대소 문자를 구분한다는 것을 알고 있습니다.
if (StringA == StringB) {
그래서 두 문자열을 둔감하게 비교하는 연산자가 있습니까?
답변
이 시도:
string.Equals(a, b, StringComparison.CurrentCultureIgnoreCase);
답변
대소 문자를 무시하고 두 문자열을 비교 하는 가장 좋은 방법 은 String.Equals 정적 메서드를 사용하여 서수 무시 문자열 비교를 지정하는 것입니다. 또한 문자열을 소문자 나 대문자로 변환 한 후 비교하는 것보다 훨씬 빠른 방법입니다.
두 가지 접근 방식의 성능을 테스트했으며 서수 무시 문자열 비교가 9 배 이상 빨랐습니다 ! 문자열을 소문자 또는 대문자로 변환하는 것보다 안정적입니다 (터키어 i 문제를 확인하십시오). 따라서 항상 String.Equals 메소드를 사용하여 문자열이 동일한 지 비교하십시오.
String.Equals(string1, string2, StringComparison.OrdinalIgnoreCase);
문화권 별 문자열 비교를 수행하려는 경우 다음 코드를 사용할 수 있습니다.
String.Equals(string1, string2, StringComparison.CurrentCultureIgnoreCase);
두 번째 예는 현재 문화권의 문자열 비교 논리를 사용하므로 첫 번째 예의 “단일 무시 무시”비교보다 느리므로 문화권 별 문자열 비교 논리가 필요하지 않은 경우 최대 성능을 유지 한 후에는 “단일 무시 무시”비교를 사용하십시오.
자세한 내용 은 내 블로그에서 전체 기사를 읽으십시오 .
답변
StringComparer
정적 클래스에는 원하는 모든 유형의 대소 문자 구분에 대한 비교자를 반환 하는 여러 속성 이 있습니다.
예를 들어
StringComparer.CurrentCultureIgnoreCase.Equals(string1, string2)
또는
StringComparer.CurrentCultureIgnoreCase.Compare(string1, string2)
인수 를 취하는 과부하 string.Equals
또는 string.Compare
과부하 보다 약간 깨끗합니다 StringComparison
.
답변
System.Collections.CaseInsensitiveComparer
또는
System.StringComparer.OrdinalIgnoreCase
답변
string.Equals(StringA, StringB, StringComparison.CurrentCultureIgnoreCase);
답변
또는
if (StringA.Equals(StringB, StringComparison.CurrentCultureIgnoreCase)) {
그러나 StringA가 null이 아닌지 확인해야합니다. 따라서 아마도 더 나은 사용법입니다.
string.Equals(StringA , StringB, StringComparison.CurrentCultureIgnoreCase);
요한이 제안한대로
편집 : 버그 수정
답변
당신이 사용할 수있는
if (stringA.equals(StringB, StringComparison.CurrentCultureIgnoreCase))