C/C++ 各类型int、long、double、char、long long取值范围(基本类型的最大最小值)

雨点打透心脏的1/2处 2022-02-23 13:25 547阅读 1赞

做题的时候经常会使用到数据类型的最大最小值(如int, long, long long, char等),我也查了很多次,这次就记下来当笔记吧。

参考了C++ prime plus、各个博客、教程和c++官网,对C/C++中各个类型int、long、double、char、long long等基本类型的取值范围即最大最小值总结如下:

在这里插入图片描述
1字节 = 8位,“位”是计算机内存的基本单元

注意:
不同的操作系统和编译器会导致变量的取值范围不同,各位可以使用以下代码查看自己操作系统的变量取值范围:

  1. #include<iostream>
  2. #include<string>
  3. #include <limits>
  4. using namespace std;
  5. int main(){
  6. cout << "[type] \t\t" << "[所占字节数]\t[最大值]\t\t[最小值]"<< endl;
  7. cout << "bool: \t\t" << sizeof(bool) << "\t\t" << (numeric_limits<bool>::max)() << "\t\t\t" << (numeric_limits<bool>::min)() << endl;
  8. cout << "char: \t\t" << sizeof(char) << "\t\t" << CHAR_MAX << "\t\t\t" << CHAR_MIN << endl;
  9. cout << "signed char: \t" << sizeof(signed char) << "\t\t" << SCHAR_MAX << "\t\t\t" << SCHAR_MIN << endl;
  10. cout << "unsigned char: \t" << sizeof(unsigned char) << "\t\t" << UCHAR_MAX << "\t\t\t" << (numeric_limits<unsigned char>::min)() << endl;
  11. cout << "wchar_t: \t" << sizeof(wchar_t) << "\t\t" << (numeric_limits<wchar_t>::max)() << "\t\t\t" << (numeric_limits<wchar_t>::min)() << endl;
  12. cout << "short: \t\t" << sizeof(short) << "\t\t" << SHRT_MAX << "\t\t\t" << SHRT_MIN << endl;
  13. cout << "int: \t\t" << sizeof(int) << "\t\t" << INT_MAX << "\t\t" << INT_MIN << endl;
  14. cout << "unsigned: \t" << sizeof(unsigned) << "\t\t" << UINT_MAX << "\t\t" << (numeric_limits<unsigned>::min)() << endl;
  15. cout << "long: \t\t" << sizeof(long) << "\t\t" << LONG_MAX << "\t\t" << LONG_MIN << endl;
  16. cout << "unsigned long: \t" << sizeof(unsigned long) << "\t\t" << ULONG_MAX << "\t\t" << (numeric_limits<unsigned long>::min)() << endl;
  17. cout << "long long: \t" << sizeof(long long) << "\t\t" << LLONG_MAX << "\t" << LLONG_MIN << endl;
  18. cout << "double: \t" << sizeof(double) << "\t\t" << (numeric_limits<double>::max)() << "\t\t" << (numeric_limits<double>::min)() << endl;
  19. cout << "long double: \t" << sizeof(long double) << "\t\t" << (numeric_limits<long double>::max)() << "\t\t" << (numeric_limits<long double>::min)() << endl;
  20. cout << "float: \t\t" << sizeof(float) << "\t\t" << (numeric_limits<float>::max)() << "\t\t" << (numeric_limits<float>::min)() << endl;
  21. cout << "size_t: \t" << sizeof(size_t) << "\t\t" << (numeric_limits<size_t>::max)() << "\t\t" << (numeric_limits<size_t>::min)() << endl;
  22. cout << "string: \t" << sizeof(string) << endl;
  23. cout << "[type] \t\t" << "[所占字节数]\t[最大值]\t\t[最小值]"<< endl;
  24. return 0;
  25. }

该代码是我查看了其他文章和教程的代码后写的,我个人认为那些代码有些乱且有错,同时我也加上了他们都漏掉的long long数据类型的取值范围。

接下来是C++官网的宏定义数据表,作为参考:
头文件:#include <climits>#include <limits.h>
在这里插入图片描述

教程中的表:
在这里插入图片描述

发表评论

表情:
评论列表 (有 0 条评论,547人围观)

还没有评论,来说两句吧...

相关阅读