Я рассматривал вопрос Одинарные кавычки и двойные кавычки на C или С++. Я не мог полностью понять объяснение, поэтому я написал программу:
#include <stdio.h>
int main()
{
  char ch = 'a';
  printf("sizeof(ch) :%d\n", sizeof(ch));
  printf("sizeof(\'a\') :%d\n", sizeof('a'));
  printf("sizeof(\"a\") :%d\n", sizeof("a"));
  printf("sizeof(char) :%d\n", sizeof(char));
  printf("sizeof(int) :%d\n", sizeof(int));
  return 0;
}
Я скомпилировал их, используя gcc и g++, и это мои выходы:
НКА:
sizeof(ch)   : 1  
sizeof('a')  : 4  
sizeof("a")  : 2  
sizeof(char) : 1  
sizeof(int)  : 4  
г ++:
sizeof(ch)   : 1  
sizeof('a')  : 1  
sizeof("a")  : 2  
sizeof(char) : 1  
sizeof(int)  : 4  
Выход g++ имеет смысл для меня, и я не сомневаюсь в этом. В gcc необходимо, чтобы sizeof('a') отличался от sizeof(char)? Есть ли какая-то фактическая причина или это просто исторический?
Также в C, если char и 'a' имеют разный размер, означает ли это, что когда мы пишем
char ch = 'a';, мы делаем неявное преобразование типов?