今天翻开c语言笔记本重新复习了一下下,果然找到了一个以前未注意的点
1 #include <stdio.h> 2 #include <limits.h> 3 4 int main(void) 5 { 6 long long num = INT_MAX + 1; 7 8 printf("%lld\n", num); 9 10 return 0; 11 }
你认为这样写对吗??
当然我这么问,表明了是不对的。
可是long long类型不是8个字节吗?存储了INT_MAX + 1还不是小菜,当然是小菜关键在于,以前没太在意的一个东西,字面值的后缀。
对,没错,编译器是根据字面值的表示法和后缀符号,来确定字面值类型的,而整形数据默认是int型的,所以INT_MAX + 1很不幸的发生了溢出,推测INT_MAX + 1应该是生成一个临时变量
再用来初始化num的吧...这里望知道的牛指点迷津。
所以应该这样写
1 #include <stdio.h> 2 #define INT_MAX 2147483647 /* maximum (signed) int value */ 3 4 int main(void) 5 { 6 long long num = 2147483647LL + 1LL; 7 8 printf("%lld", num); 9 return 0; 10 }
//#include <stdio.h>
//#include <limits.h>
//
//int main(void)
//{
// long long num = 2147483648L; // 这里是L 代表long 而不是 long long
//
// printf("%lld\n", num);
//
// return 0;
//}
貌似这样写输出也没问题?