C와 C의 문자 크기 차이
C와 C 모두에서 sizeof 연산자는 데이터 유형의 크기에 대한 정보를 제공합니다. 변하기 쉬운. 프로그래머는 이 연산자를 사용하여 프로그램의 출력을 검사함으로써 작업 중인 데이터에 대한 중요한 세부 정보를 배울 수 있습니다. 그러나 놀랍게도 C와 C 사이의 문자 값에 sizeof 연산자를 적용하면 다른 결과가 나타납니다.
다음 C 프로그램을 고려하세요.
#include <stdio.h> int main(void) { printf("sizeof(char) = %zu\n", sizeof(char)); printf("sizeof('a') = %zu\n", sizeof('a')); }
실행 시 이 프로그램은 다음을 인쇄합니다.
sizeof(char) = 1 sizeof('a') = 4
이제 C로 작성된 동일한 프로그램을 살펴보겠습니다. :
#include <iostream> int main() { std::cout << "sizeof(char) = " << sizeof(char) << std::endl; std::cout << "sizeof('a') = " << sizeof('a') << std::endl; }
C에서 실행하면 다음이 출력됩니다.
sizeof(char) = 1 sizeof('a') = 1
주요 차이점은 C와 C가 내부적으로 문자 상수를 나타내는 방식에 있습니다. C에서 'a'와 같은 문자 상수는 해당 ASCII 값을 갖는 정수로 처리됩니다. 이것이 C에서 sizeof('a')가 4를 반환하는 이유입니다. 정수의 크기는 일반적으로 4바이트이기 때문입니다. 반면 C에서는 문자 상수를 char 데이터형으로 취급하며 크기는 1바이트이다.
위 내용은 C와 C 사이에서 `sizeof('a')`가 다른 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!