양수 Unsigned Int와 음수 비교?
C에서는 서로 다른 유형의 값을 비교하는 상황이 자주 발생합니다. 그러나 이러한 비교가 어떻게 작동하는지 이해하는 것은 까다로울 수 있습니다.
다음 코드를 고려하세요.
#include <iostream> #include <vector> int main() { std::vector<int> a; std::cout << "vector size " << a.size() << std::endl; int b = -1; if (b < a.size()) std::cout << "Less"; else std::cout << "Greater"; }
코드는 "-1"이 "0.0"보다 확실히 작음에도 불구하고 "Greater"를 인쇄합니다. " 왜 이런 일이 발생합니까?
핵심은 관련된 다양한 데이터 유형에 있습니다. a.size()는 부호 없는 정수를 반환하고, b는 부호 있는 음의 정수를 반환합니다. 이 두 가지 유형을 비교할 때 음의 부호 있는 정수는 부호 없는 정수로 승격됩니다. 이로 인해 0과 비교되는 큰 부호 없는 값이 발생하며 이는 확실히 더 큽니다.
이를 더 자세히 설명하기 위해 다음 예를 살펴보겠습니다.
#include <iostream> int main() { std::cout << std::boolalpha; unsigned int a = 0; int b = -1; std::cout << (b < a) << "\n"; // prints "false" }
이 경우 결과는 예상대로 "거짓"입니다. 이는 a와 b가 모두 부호 없는 정수로 승격되고 "-1"이 이제 0보다 큰 부호 없는 큰 값이기 때문입니다.
위 내용은 C에서 음수를 부호 없는 정수와 비교하면 예기치 않은 결과가 나타나는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!