Próbuję tego kodu na kompilatorze GNU C ++ i nie jestem w stanie zrozumieć jego zachowania:
#include <stdio.h>;
int main()
{
int num1 = 1000000000;
long num2 = 1000000000;
long long num3;
//num3 = 100000000000;
long long num4 = ~0;
printf("%u %u %u", sizeof(num1), sizeof(num2), sizeof(num3));
printf("%d %ld %lld %llu", num1, num2, num3, num4);
return 0;
}
Kiedy odkomentuję skomentowaną linię, kod nie kompiluje się i wyświetla błąd:
błąd: stała całkowita jest za duża dla typu długiego
Ale jeśli kod zostanie skompilowany tak, jak jest i jest wykonywany, generuje wartości znacznie większe niż 10000000000.
Czemu?
<stdint.h>
i użycieuint64_t
. Aby wyświetlić wartość 64-bitową,printf( "%" PRIu64 "\n", val);