이 글에서는 주로 C#의 특수한 문자열 유형을 소개합니다. 참조값이 아주 좋은데 아래 에디터로 살펴보겠습니다
1. 서문
문자열은 참조형이니까 다들 아시죠? ? 그런데 사용하는 과정에서 여전히 값 유형의 특성이 일부 존재한다는 것을 알게 되었습니다. 왜 그럴까요?
이유는 닷넷에서는 문자열 객체를 많이 조작하고, 참조 객체를 많이 조작하면 당연히 값형만큼 성능이 빠르지 않을 것이라고 생각하기 때문입니다. 이 성능을 향상시키기 위해 .Net은 문자열 상주 풀이라는 특별한 솔루션을 제공합니다!
2. 텍스트
먼저 코드를 살펴보겠습니다.
string str1 = "aa"; string str2 = "a" + "a"; Console.WriteLine(ReferenceEquals(str1, str2)); //print:true
이 str1 str2가 가리키는 메모리 주소는 실제로 정확히 동일합니다!
이유는 .Net이 CLR(실제로 위에서 언급한 문자열 상주 풀) 내부에 해시 테이블을 유지 관리하고, 키는 문자열 콘텐츠이고, 값은 관리되는 힙의 주소이기 때문입니다. 생성을 위해 초기화됨 새 문자열이 생성되면 .Net은 동일한 값이 있는지 확인하기 위해 해시 테이블을 검색합니다. 키가 동일한 경우 기존 문자열의 주소 값이 새로 생성된 문자열에 할당됩니다. 그렇지 않으면 기존 문자열의 주소 값이 새로 생성된 문자열에 할당됩니다. 존재하는 경우 주소가 다시 할당되므로 위 코드의 메모리가 true입니다.
다른 코드를 살펴보겠습니다:
string str3 = "ab"; string str4 = "a"; str4 += "b"; Console.WriteLine(ReferenceEquals(str3, str4));//print :false
false가 나타나는 이유는 "초기화" 키워드에 주목하세요. 이전 열 Create", 문자열이 동적으로 생성되면 .Net은 생성되었는지 확인하기 위해 Hash 테이블에서 검색하지 않고 직접 생성합니다.
위 코드를 최적화하려는 경우 (xian) 높은(de) 추적(dan) 추구(teng) 성능을 향상시킵니다. 비교를 위해 이 문자열을 문자열 상주 풀에 수동으로 추가할 수 있습니다
string str3 = "ab"; string str4 = "a"; str4 += "b"; str4 = string.Intern(str4);//Intern:它会去字符串驻留池中搜索,假如找寻到的话则返回对应的地址 Console.WriteLine(ReferenceEquals(str3, str4));//print :true
3. 요약
마지막으로 문자열에 대한 몇 가지 결론:
1. 문자열은 clr의 newobj 명령으로 생성되지 않지만 ldstr 명령으로 생성되었습니다! 게다가 문자열은 값 유형의 특성을 가지지만 메모리에서는 참조 유형이며 관리되는 힙에 존재합니다.
2. 클래스 통합이 불가능합니다.
3. 생성된 콘텐츠가 동일한 경우 문자열은 동일한 주소를 가리키며 문자열에 대한 각 작업은 새 주소 생성(문자열의 불변성)
4. 문자열과 달리 동적이기 때문에 StringBuilder를 사용하는 것이 좋습니다. 상수이지만 StringBuilder를 생성하는 데 비용이 더 많이 들기 때문에 작은 접합에는 문자열을 사용하는 것이 성능 측면에서 더 좋을 수 있습니다!
위는 C#의 특수 문자열 유형 코드 예제에 대한 자세한 설명입니다. PHP 중국어 홈페이지(www.php.cn)!