> 백엔드 개발 > C++ > C 표현식에서 다중 사후 증분의 출력을 예측할 수 없는 이유는 무엇입니까?

C 표현식에서 다중 사후 증분의 출력을 예측할 수 없는 이유는 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2024-11-05 21:58:02
원래의
435명이 탐색했습니다.

Why is the Output of Multiple Post Increments in a C   Expression Unpredictable?

C의 Post Increment 동작

C에서 Post Increment(예: i )는 변수를 증가시키지만 원래 값을 반환합니다. 복잡한 표현식에서는 해당 동작을 이해하는 것이 중요합니다.

다음 코드를 고려하세요.

<code class="cpp">int i = 5;

cout << i++ << i-- << ++i << --i << i << endl;</code>
로그인 후 복사

이 문은 결과를 출력하기 전에 i i-- i --i i 표현식을 평가합니다. 그러나 평가 순서가 정의되지 않아 예측할 수 없는 출력(예: "45555")이 발생합니다.

시퀀스 포인트 규칙을 분석해 보겠습니다.

  • 시퀀스 포인트: C에서 코드의 특정 지점은 보류 중인 작업을 강제로 평가합니다. 이러한 점에는 세미콜론(;), 쉼표(,) 및 명령문의 끝이 포함됩니다.
  • 정의되지 않은 동작: 위 코드에는 스칼라 변수 i에 대한 순서 없는 부작용이 있습니다. 사후 증분 작업으로 인해. 이로 인해 정의되지 않은 동작이 발생합니다.

예:

<code class="cpp">int x = 20, y = 35;

x = y++ + y + x++ + y++;</code>
로그인 후 복사

이 표현식은 다음 순서로 평가됩니다.

  1. y : y를 36으로 증가시키고 35(y의 원래 값)를 반환합니다.
  2. x : x를 21로 증가시키고 20(x의 원래 값)을 반환합니다.
  3. y : y를 2로 증가시킵니다. 37이고 36(y의 원래 값)을 반환합니다.
  4. x : x를 22로 증가시키고 21(x의 원래 값)을 반환합니다.

따라서 최종 값은 x는 126(35 36 20 21)이고 y는 37입니다.

결론:

C의 사후 증분은 순서가 없는 표현식에 사용될 때 정의되지 않은 동작으로 이어질 수 있습니다. 시퀀스 포인트를 이해하고 시퀀스되지 않은 컨텍스트 내에서 동일한 변수에 대한 부작용을 피하는 것이 중요합니다.

위 내용은 C 표현식에서 다중 사후 증분의 출력을 예측할 수 없는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿