[数据结构]细说0xFFFFFFFFL

0xFFFFFFFFL 是一个编程中常见的十六进制长整型(long)字面量。

核心含义

  • 数值大小:十进制为 4,294,967,295 (232−12^{32} - 1232−1)。
  • 二进制表示:32个1,即 11111111 11111111 11111111 11111111
  • 后缀 L:表示该数值的数据类型为 Long(长整型,通常为64位),而非默认的 Int(整型,通常为32位)。

为什么需要加 "L"?

在 Java、C#等强类型语言中,如果不加后缀,0xFFFFFFFF 会被默认解析为 int 类型。由于 int 是有符号的32位整数,最高位为符号位,全1的二进制补码表示 -1。

加上 L 后,编译器将其视为 long 类型。long 是64位有符号整数,0xFFFFFFFFL 的高32位自动补0,低32位为全1。因此,它被正确解释为一个巨大的正数,而不是负数。

常见应用场景

主要用于将有符号的32位整数转换为无符号的64位长整数,以保留其原始位模式代表的正值。

例如在 Java 中读取网络字节流或文件中的无符号32位整数时:

java 复制代码
// 假设 bf.getInt() 返回一个 int,其二进制为 0xFFFFFFFF (-1)
int signedValue = bf.getInt(); 

// 错误做法:直接赋值,结果仍为 -1
long wrong = signedValue; 

// 正确做法:与 0xFFFFFFFFL 进行按位与 (&) 操作
// 这将把 int 提升为 long,并屏蔽掉高32位的符号扩展,只保留低32位
long unsignedValue = signedValue & 0xFFFFFFFFL; 
// 此时 unsignedValue 的值为 4294967295

总结对比

写法 数据类型 十进制值 说明
0xFFFFFFFF int (32位) -1 有符号整数,全1为补码-1
0xFFFFFFFFL long (64位) 4,294,967,295 长整数,高32位为0,低32位为全1
相关推荐
不会就选b2 小时前
数据结构之链表OJ题(下)
数据结构·链表
小七在进步2 小时前
数据结构:线性表之单链表
c语言·数据结构
洛水水2 小时前
【力扣100题】89.下一个排列
数据结构·算法·leetcode
鱼子星_2 小时前
【数据结构】排序的拓展——快速排序的生态多样性与归并排序沾染文件操作
c语言·数据结构·算法
kkkAloha3 小时前
链表解题总结
数据结构·链表
05候补工程师3 小时前
【408考研复习】数据结构核心笔记:字符串模式匹配与内部排序算法全解析
数据结构·经验分享·笔记·考研·算法·排序算法
欧阳x天3 小时前
八大排序算法(C语言实现)
数据结构·算法·排序算法
SoftLipaRZC6 小时前
单链表的应用:经典OJ题与通讯录项目实战
数据结构
SoftLipaRZC6 小时前
单链表专题:从概念到实现
数据结构