C/C++中各种类型int、long、double、char表示范围(最大最小值)

2024-03-25 00:58

本文主要是介绍C/C++中各种类型int、long、double、char表示范围(最大最小值),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原文地址:http://blog.csdn.net/xuexiacm/article/details/8122267

这一内容虽然十分基础,但是有时候也比较容易忽略数值范围的问题!

[cpp]  view plain copy
  1. #include<iostream>  
  2. #include<string>  
  3. #include <limits>  
  4. using namespace std;  
  5.   
  6. int main()  
  7. {  
  8.     cout << "type: \t\t" << "************size**************"<< endl;  
  9.     cout << "bool: \t\t" << "所占字节数:" << sizeof(bool);  
  10.     cout << "\t最大值:" << (numeric_limits<bool>::max)();  
  11.     cout << "\t\t最小值:" << (numeric_limits<bool>::min)() << endl;  
  12.     cout << "char: \t\t" << "所占字节数:" << sizeof(char);  
  13.     cout << "\t最大值:" << (numeric_limits<char>::max)();  
  14.     cout << "\t\t最小值:" << (numeric_limits<char>::min)() << endl;  
  15.     cout << "signed char: \t" << "所占字节数:" << sizeof(signed char);  
  16.     cout << "\t最大值:" << (numeric_limits<signed char>::max)();  
  17.     cout << "\t\t最小值:" << (numeric_limits<signed char>::min)() << endl;  
  18.     cout << "unsigned char: \t" << "所占字节数:" << sizeof(unsigned char);  
  19.     cout << "\t最大值:" << (numeric_limits<unsigned char>::max)();  
  20.     cout << "\t\t最小值:" << (numeric_limits<unsigned char>::min)() << endl;  
  21.     cout << "wchar_t: \t" << "所占字节数:" << sizeof(wchar_t);  
  22.     cout << "\t最大值:" << (numeric_limits<wchar_t>::max)();  
  23.     cout << "\t\t最小值:" << (numeric_limits<wchar_t>::min)() << endl;  
  24.     cout << "short: \t\t" << "所占字节数:" << sizeof(short);  
  25.     cout << "\t最大值:" << (numeric_limits<short>::max)();  
  26.     cout << "\t\t最小值:" << (numeric_limits<short>::min)() << endl;  
  27.     cout << "int: \t\t" << "所占字节数:" << sizeof(int);  
  28.     cout << "\t最大值:" << (numeric_limits<int>::max)();  
  29.     cout << "\t最小值:" << (numeric_limits<int>::min)() << endl;  
  30.     cout << "unsigned: \t" << "所占字节数:" << sizeof(unsigned);  
  31.     cout << "\t最大值:" << (numeric_limits<unsigned>::max)();  
  32.     cout << "\t最小值:" << (numeric_limits<unsigned>::min)() << endl;  
  33.     cout << "long: \t\t" << "所占字节数:" << sizeof(long);  
  34.     cout << "\t最大值:" << (numeric_limits<long>::max)();  
  35.     cout << "\t最小值:" << (numeric_limits<long>::min)() << endl;  
  36.     cout << "unsigned long: \t" << "所占字节数:" << sizeof(unsigned long);  
  37.     cout << "\t最大值:" << (numeric_limits<unsigned long>::max)();  
  38.     cout << "\t最小值:" << (numeric_limits<unsigned long>::min)() << endl;  
  39.     cout << "double: \t" << "所占字节数:" << sizeof(double);  
  40.     cout << "\t最大值:" << (numeric_limits<double>::max)();  
  41.     cout << "\t最小值:" << (numeric_limits<double>::min)() << endl;  
  42.     cout << "long double: \t" << "所占字节数:" << sizeof(long double);  
  43.     cout << "\t最大值:" << (numeric_limits<long double>::max)();  
  44.     cout << "\t最小值:" << (numeric_limits<long double>::min)() << endl;  
  45.     cout << "float: \t\t" << "所占字节数:" << sizeof(float);  
  46.     cout << "\t最大值:" << (numeric_limits<float>::max)();  
  47.     cout << "\t最小值:" << (numeric_limits<float>::min)() << endl;  
  48.     cout << "size_t: \t" << "所占字节数:" << sizeof(size_t);  
  49.     cout << "\t最大值:" << (numeric_limits<size_t>::max)();  
  50.     cout << "\t最小值:" << (numeric_limits<size_t>::min)() << endl;  
  51.     cout << "string: \t" << "所占字节数:" << sizeof(string) << endl;  
  52.     // << "\t最大值:" << (numeric_limits<string>::max)() << "\t最小值:" << (numeric_limits<string>::min)() << endl;  
  53.     cout << "type: \t\t" << "************size**************"<< endl;  
  54.     return 0;  
  55. }  



/*运行结果分析:

以上结果已经很明白了,一下补充说明几点:

概念、整型:表示整数、字符和布尔值的算术类型合称为整型(integral type)

关于带符号与无符号类型:整型 int、stort  和  long 都默认为带符号型。要获得无符号型则必须制定该类型为unsigned,比如unsigned long。unsigned int类型可以简写为unsigned,也就是说,unsigned后不加其他类型说明符就意味着是unsigned int。

一字节表示八位,即:1byte = 8 bit;

int: 4byte =  32 bit 有符号signed范围:2^31-1 ~ -2^31即:2147483647 ~ -2147483648无符号unsigned范围:2^32-1 ~ 0即:4294967295 ~ 0

long: 4 byte = 32 bit 同int型

double: 8 byte = 64 bit 范围:1.79769e+308 ~ 2.22507e-308

long double: 12 byte = 96 bit 范围: 1.18973e+4932 ~ 3.3621e-4932

float: 4 byte = 32 bit 范围: 3.40282e+038 ~ 1.17549e-038

int、unsigned、long、unsigned long 、double的数量级最大都只能表示为10亿,即它们表示十进制的位数不超过10个,即可以保存所有9位整数。而short只是能表示5位;


另外对于浮点说而言:使用double类型基本上不会有错。在float类型中隐式的精度损失是不能忽视的,二双精度计算的代价相对于单精度可以忽略。事实上,在有些机器上,double类型比float类型的计算要快得多。float型只能保证6位有效数字,而double型至少可以保证15位有效数字(小数点后的数位),long double型提供的精度通常没有必要,而且还要承担额外的运行代价。

double是8字节共64位,其中小数位占52位,2-^52=2.2204460492503130808472633361816e-16,量级为10^-16,故能够保证2^-15的所有精度。

在有些机器上,用long类型进行计算所付出的运行时代价远远高于用int类型进行同样计算的代价,所以算则类型前要先了解程序的细节并且比较long类型与int类型的实际运行时性能代价。


这篇关于C/C++中各种类型int、long、double、char表示范围(最大最小值)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/843375

相关文章

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

C++中悬垂引用(Dangling Reference) 的实现

《C++中悬垂引用(DanglingReference)的实现》C++中的悬垂引用指引用绑定的对象被销毁后引用仍存在的情况,会导致访问无效内存,下面就来详细的介绍一下产生的原因以及如何避免,感兴趣... 目录悬垂引用的产生原因1. 引用绑定到局部变量,变量超出作用域后销毁2. 引用绑定到动态分配的对象,对象

C++读写word文档(.docx)DuckX库的使用详解

《C++读写word文档(.docx)DuckX库的使用详解》DuckX是C++库,用于创建/编辑.docx文件,支持读取文档、添加段落/片段、编辑表格,解决中文乱码需更改编码方案,进阶功能含文本替换... 目录一、基本用法1. 读取文档3. 添加段落4. 添加片段3. 编辑表格二、进阶用法1. 文本替换2

C++中处理文本数据char与string的终极对比指南

《C++中处理文本数据char与string的终极对比指南》在C++编程中char和string是两种用于处理字符数据的类型,但它们在使用方式和功能上有显著的不同,:本文主要介绍C++中处理文本数... 目录1. 基本定义与本质2. 内存管理3. 操作与功能4. 性能特点5. 使用场景6. 相互转换核心区别

C++右移运算符的一个小坑及解决

《C++右移运算符的一个小坑及解决》文章指出右移运算符处理负数时左侧补1导致死循环,与除法行为不同,强调需注意补码机制以正确统计二进制1的个数... 目录我遇到了这么一个www.chinasem.cn函数由此可以看到也很好理解总结我遇到了这么一个函数template<typename T>unsigned

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基

基于Python实现数字限制在指定范围内的五种方式

《基于Python实现数字限制在指定范围内的五种方式》在编程中,数字范围限制是常见需求,无论是游戏开发中的角色属性值、金融计算中的利率调整,还是传感器数据处理中的异常值过滤,都需要将数字控制在合理范围... 目录引言一、基础条件判断法二、数学运算巧解法三、装饰器模式法四、自定义类封装法五、NumPy数组处理