C/C++ 数据类型选择笔记:int、long long、char、string、float、double

在 C/C++ 编程中,选择合适的数据类型不仅影响 内存占用 ,还关系到 效率与精度 。本文系统总结了常见数据类型的 字节大小、位数、取值范围、适用场景和注意事项,帮助大家写出更高质量的代码。


1. int

  • 字节数:4 字节(32 位)。

  • 范围

    • 十进制:-2,147,483,648 ~ 2,147,483,647

    • 幂次方:-2^31 ~ 2^31 - 1

  • 适用场景:循环计数、数组下标、绝大多数整数运算。

  • 注意 :超过 ±2^31 时请改用 long long


2. long long

  • 字节数:8 字节(64 位)。

  • 范围

    • 十进制:-9,223,372,036,854,775,808 ~ 9,223,372,036,854,775,807

    • 幂次方:-2^63 ~ 2^63 - 1

  • 适用场景 :大整数运算(如 10^12 级别)、算法竞赛、结果可能超出 int 时。

  • 注意 :输入输出需使用 %lld,避免与 int 混用。


3. char

  • 字节数:1 字节(8 位)。

  • 范围

    • 有符号:-128 ~ 127,即 -2^7 ~ 2^7 - 1

    • 无符号:0 ~ 255,即 0 ~ 2^8 - 1

  • 适用场景 :单个字符(如 'a''1')、ASCII 处理、小范围整数。

  • 注意char 既可作字符,也可作 1 字节整数,数值运算需谨慎。


4. string(C++ 专用)

  • 说明 :基于 std::basic_string<char>,每个字符占 1 字节(8 位),整体大小随内容动态变化。

  • 适用场景:文本处理、拼接、查找、子串操作。

  • 注意

    • cin >> s 遇空格会截断,整行输入需用 getline()

    • 与 C 接口交互时可用 s.c_str() 转换为 const char*


5. float

  • 字节数:4 字节(32 位,符合 IEEE 754 单精度标准)。

  • 范围 :约 ±3.4 × 10^38

  • 指数范围 :约 2^-126 ~ 2^127

  • 有效精度7 位有效数字(约能保证小数点后 6 位)。

  • 适用场景

    • 内存敏感场景(嵌入式设备、大规模浮点数组)。

    • 对精度要求不高的近似计算(如图形学、绘图坐标)。

  • 注意:精度有限,大量运算会积累误差;金融和高精度科学计算不推荐。


6. double

  • 字节数:8 字节(64 位,符合 IEEE 754 双精度标准)。

  • 范围 :约 ±1.7 × 10^308

  • 指数范围 :约 2^-1022 ~ 2^1023

  • 有效精度15~16 位有效数字(约能保证小数点后 15 位)。

  • 适用场景

    • 默认推荐:常规浮点运算。

    • 科学计算:对精度要求较高的场景。

  • 注意

    • 默认浮点字面量是 double(例如 3.14)。

    • 若需更高精度,可使用 long double 或大数库。


类型选择速查表

类型 字节数 位数 范围(十进制) 范围(幂次方) 精度/适用场景
int 4B 32b -2,147,483,648 ~ 2,147,483,647 -2^31 ~ 2^31-1 常用整数,±21 亿以内
long long 8B 64b -9.22e18 ~ 9.22e18 -2^63 ~ 2^63-1 大整数运算、竞赛
char 1B 8b -128 ~ 127 / 0 ~ 255 -2^7 ~ 2^7-1 / 0~2^8-1 字符、ASCII、小整数
string 动态 动态 取决于长度 - 文本处理
float 4B 32b ±3.4e38 2^-126 ~ 2^127 ~7 位有效数字,节省内存
double 8B 64b ±1.7e308 2^-1022 ~ 2^1023 ~15 位有效数字,默认推荐
相关推荐
freedom_1024_14 分钟前
LRU缓存淘汰算法详解与C++实现
c++·算法·缓存
无敌最俊朗@27 分钟前
C++-Qt-音视频-基础问题01
开发语言·c++
折戟不必沉沙27 分钟前
C++四种类型转换cast,其在参数传递时的作用
c++
kyle~29 分钟前
C++---万能指针 void* (不绑定具体数据类型,能指向任意类型的内存地址)
开发语言·c++
誰能久伴不乏41 分钟前
Linux 进程通信与同步机制:共享内存、内存映射、文件锁与信号量的深度解析
linux·服务器·c++
_F_y1 小时前
C++异常
c++
小龙报1 小时前
《算法通关指南:算法基础篇 --- 一维前缀和 — 1. 【模板】一维前缀和,2.最大子段和》
c语言·数据结构·c++·算法·职场和发展·创业创新·visual studio
R6bandito_2 小时前
STM32 HAL库原子操作编译问题解决指南
c语言·ide·经验分享·stm32·单片机·嵌入式硬件·mcu
郝学胜-神的一滴2 小时前
Effective STL 第9条:C++容器元素删除技巧详解
开发语言·c++·程序人生·stl
树在风中摇曳2 小时前
LeetCode 1658 | 将 x 减到 0 的最小操作数(C语言滑动窗口解法)
c语言·算法·leetcode