C에서 문자열과 문자 리터럴 연결
C에서는 문자열과 문자를 연결하는 데 연산자를 사용할 수 있습니다. 그러나 이 동작은 관련된 피연산자 유형에 따라 다릅니다.
다음 코드를 고려하세요.
<code class="cpp">string str = "ab" + 'c'; cout << str << endl;</code>
이 코드는 예상대로 "abc" 출력을 생성합니다. 이는 문자열 리터럴 "ab"가 자동으로 const char* 포인터로 변환되기 때문입니다. 문자 리터럴 'c'는 정수 값으로 승격되어 문자열 리터럴의 주소에 추가됩니다. 결과는 "abc" 문자를 포함하는 새 문자열입니다.
그러나 다음 대안을 고려하십시오.
<code class="cpp">char ch = 'c'; string str1 = "ab"; string str2 = str1 + ch; cout << str2 << endl;</code>
이 코드는 예상치 못한 "ed" 출력을 생성합니다.
이 동작을 이해하려면 먼저 문자열 str1이 const char*가 아닌 string 유형이라는 점을 관찰해야 합니다. 문자열에 문자 ch를 추가하면 컴파일러는 문자열 개체에 대해 오버로드된 연산자를 사용하려고 시도합니다. 그러나 string 및 char에 대한 연산자 오버로드는 없습니다.
이 모호성을 해결하기 위해 컴파일러는 ch를 정수로 승격하고 첫 번째 예와 같이 추가를 수행합니다. 그러나 결과 주소는 문자열 str1에 할당된 메모리를 지나므로 정의되지 않은 동작이 발생합니다. null 문자가 나타날 때까지 이 주소에서 문자가 검색되어 예기치 않은 출력이 발생합니다.
이 동작을 방지하려면 'c'를 추가하기 전에 "ab"를 문자열에 명시적으로 캐스팅할 수 있습니다.
<code class="cpp">string str = std::string("ab") + 'c';</code>
또는 연결 연산자 =:
<code class="cpp">string str = "ab"; str += 'c';</code>
이 두 접근 방식 모두 결과가 유효한 문자열인지 확인할 수 있습니다.
위 내용은 C에서 문자를 문자열에 연결하면 때때로 예기치 않은 출력이 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!