C에서 문자열과 숫자의 예기치 않은 연결: "456" 1 탐색
코드 조각
< 사전>#include
int main()
{
std::cout << "25"+1; return 0;
}
은 당황스러운 질문을 던집니다. "25"라는 표현은 왜 " 1은 예상된 "26" 대신 "5"를 출력합니까? 이 수수께끼를 풀기 위해 이 코드의 내부 작동 방식을 자세히 살펴보겠습니다.
C에서 "25"와 같은 문자열 리터럴은 실제 문자열이 아닌 문자 배열로 처리됩니다. 주어진 예에서 "25"는 문자 배열 {'2', '5', ' '}와 동일합니다. 여기서 ' '는 문자열의 끝을 나타내는 null 종결자입니다.
배열이 명시적인 캐스팅 없이 표현식에 사용되면 자동으로 첫 번째 요소에 대한 포인터로 붕괴됩니다. 따라서 "25"는 문자 '2'에 대한 포인터인 &"25"[0]으로 사실상 붕괴됩니다. 이 포인터에 1을 추가하면 다음 문자인 '5'를 가리키도록 포인터가 증가합니다.
std::cout의 유형인 std::ostream의 동작을 고려하면 플롯이 두꺼워집니다. 이 클래스는 char 및 const char(char*가 붕괴됨)을 모두 허용하고 이를 null로 끝나는 문자열로 해석할 수 있습니다. 따라서 &"25"[0]을 수신하면 null 종결자를 만날 때까지 해당 포인터의 문자를 인쇄하여 결과적으로 "5"가 출력으로 표시됩니다.
위 내용은 C에서 \'25\' 1이 \'5\'를 출력하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!