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

本文总结了C/C++中各种基本数据类型的取值范围及最大最小值,包括int、long、double等,并提供了代码示例来帮助读者了解其在不同操作系统和编译器下的实际表现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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

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

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

#include<iostream>  
#include<string>  
#include <limits>  
using namespace std;  
  
int main(){  
    cout << "[type] \t\t" << "[所占字节数]\t[最大值]\t\t[最小值]"<< endl;  
    cout << "bool: \t\t" <<  sizeof(bool) << "\t\t" << (numeric_limits<bool>::max)() << "\t\t\t" << (numeric_limits<bool>::min)() << endl;  
    cout << "char: \t\t" <<  sizeof(char) << "\t\t" << CHAR_MAX << "\t\t\t" << CHAR_MIN << endl;  
    cout << "signed char: \t"  << sizeof(signed char) << "\t\t" << SCHAR_MAX << "\t\t\t" << SCHAR_MIN << endl;  
    cout << "unsigned char: \t" <<  sizeof(unsigned char) << "\t\t" << UCHAR_MAX << "\t\t\t" << (numeric_limits<unsigned char>::min)() << endl;  
    cout << "wchar_t: \t" << sizeof(wchar_t) << "\t\t" << (numeric_limits<wchar_t>::max)() << "\t\t\t" << (numeric_limits<wchar_t>::min)() << endl;  
    cout << "short: \t\t" <<  sizeof(short) << "\t\t" << SHRT_MAX << "\t\t\t" << SHRT_MIN << endl;  
    cout << "int: \t\t" <<  sizeof(int) << "\t\t" << INT_MAX << "\t\t" << INT_MIN << endl;  
    cout << "unsigned: \t" << sizeof(unsigned) << "\t\t" << UINT_MAX << "\t\t" << (numeric_limits<unsigned>::min)() << endl;  
    cout << "long: \t\t" << sizeof(long) << "\t\t" << LONG_MAX << "\t\t" << LONG_MIN << endl;  
    cout << "unsigned long: \t" << sizeof(unsigned long) << "\t\t" << ULONG_MAX << "\t\t" << (numeric_limits<unsigned long>::min)() << endl;  
    cout << "long long: \t" <<  sizeof(long long) << "\t\t" << LLONG_MAX << "\t" << LLONG_MIN << endl;  
    cout << "double: \t" << sizeof(double) << "\t\t" << (numeric_limits<double>::max)() << "\t\t" << (numeric_limits<double>::min)() << endl;
	 cout << "long double: \t" <<  sizeof(long double) << "\t\t" << (numeric_limits<long double>::max)() << "\t\t" << (numeric_limits<long double>::min)() << endl;    
    cout << "float: \t\t" <<  sizeof(float) << "\t\t" << (numeric_limits<float>::max)() << "\t\t" << (numeric_limits<float>::min)() << endl;  
    cout << "size_t: \t" << sizeof(size_t) << "\t\t" << (numeric_limits<size_t>::max)() << "\t\t" << (numeric_limits<size_t>::min)() << endl;  
    cout << "string: \t" << sizeof(string) << endl;  
    cout << "[type] \t\t" << "[所占字节数]\t[最大值]\t\t[最小值]"<< endl;   
    return 0;  
}

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

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

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

C++ 中,基本数据类型取值范围取决于其类型和所使用的系统架构(如 32 位或 64 位系统)。以下是常见的基本数据类型及其典取值范围。 ### 整Integer Types) 整用于存储不带小数部分的数值。C++ 提供了多种整以适应不同的需求: - **`char`**:通常占用 1 字节,其取值范围为 -128 到 127(有符号)或 0 到 255(无符号)。 - **`short`**:通常占用 2 字节,其取值范围为 -32,768 到 32,767(有符号)或 0 到 65,535(无符号)。 - **`int`**:通常占用 4 字节,其取值范围为 -2,147,483,648 到 2,147,483,647(有符号)或 0 到 4,294,967,295(无符号)。 - **`long`**:通常占用 4 或 8 字节,具体取决于平台,取值范围与 `int` 类似或更大。 - **`long long`**:通常占用 8 字节,其取值范围为 -9,223,372,036,854,775,808 到 9,223,372,036,854,775,807(有符号)或 0 到 18,446,744,073,709,551,615(无符号)。 需要注意的是,整变量即使被赋予浮点数,也只会保留其整数部分。例如,`int x = 3.75;` 会导致 `x` 的值为 `3`,而不是四舍五入的结果[^1]。 ### 浮点(Floating-Point Types) 浮点用于存储带有小数部分的数值: - **`float`**:单精度浮点数,通常占用 4 字节,其取值范围为大约 ±1.2e-38 到 ±3.4e38。 - **`double`**:双精度浮点数,通常占用 8 字节,其取值范围为大约 ±2.2e-308 到 ±1.8e308。 - **`long double`**:长双精度浮点数,通常占用 8 或 12 字节,其取值范围与 `double` 相似或更大,具体取决于平台[^2]。 ### 使用标准库查询取值范围 为了确保程序的可移植性,可以使用 C++ 标准库中的 `<limits>` 头文件来查询特定平台上各数据类型取值范围。例如: ```cpp #include <iostream> #include <limits> int main() { std::cout << "int 最大值: " << std::numeric_limits<int>::max() << std::endl; std::cout << "int 最小值: " << std::numeric_limits<int>::min() << std::endl; std::cout << "double 最小值: " << std::numeric_limits<double>::min() << std::endl; std::cout << "double 最大值: " << std::numeric_limits<double>::max() << std::endl; return 0; } ``` 这段代码将输出 `int` 和 `double` 类型最大值最小值,帮助开发者更好地理解当前平台上的数据类型特性[^3]。 ### 总结 C++ 中的基本数据类型提供了广泛的数值表示能力,从简单的字符到复杂的长双精度浮点数。了解这些类型取值范围对于编写高效、可靠的程序至关重要。通过使用标准库提供的工具,可以轻松获取这些信息并确保程序在不同环境下的兼容性和稳定性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值