php十六进制转十进制 php怎么定义十六进制整型【汇总】

3次阅读

php中十六进制整型字面量以0x开头,如0xff→255;字符串需hexdec()转换,不可直接运算;超大数用gmp;输出推荐dechex()或sprintf()按需选择。

php十六进制转十进制 php怎么定义十六进制整型【汇总】

PHP 里怎么写十六进制整型字面量

直接用 0x 开头,后面跟十六进制数字(0-9a-fA-F),PHP 解析时自动转成十进制整数存进变量。

常见错误是漏掉 0x 前缀,比如写成 $n = abcd;$n = "abcd"; —— 前者报 Parse Error: syntax error,后者存的是字符串,不是数。

  • $n = 0xff; → 十进制 255
  • $n = 0x1A; → 十进制 26
  • $n = 0XDEAD; → 大小写不敏感,0X 也行
  • 不能带空格:0x ff 是语法错误

hexdec() 和 base_convert() 的区别在哪

hexdec() 专用于把十六进制字符串转十进制整数,快、准、只认 0-9a-f(忽略前导空格和 0x 前缀);base_convert() 是通用进制转换函数,但返回的是字符串,且在大数时可能丢失精度。

比如处理 "1000000000000000" 这种长十六进制串:hexdec() 可能溢出变 INF(取决于平台整型位宽),而 base_convert() 虽然不报错,但返回的字符串结果在后续数学运算中容易出错。

立即学习PHP免费学习笔记(深入)”;

  • 优先用 hexdec("ff") → 返回 int(255)
  • 别用 base_convert("ff", 16, 10) → 返回 "255"(字符串)
  • hexdec() 不接受 0x 前缀字符串,hexdec("0xff") 会截断为 0
  • 超大值(如 64 位以上)建议用 gmp_init($hex, 16) 配合 gmp_strval()

为什么 var_dump(0x100) 显示 int(256),但 echo “0x100” 输出字符串

因为 0x100 是整数字面量,PHP 编译期就完成了进制解析;而 "0x100" 是字符串,引号包住的内容完全按字面意思存,不会触发任何进制转换逻辑。

这个混淆点常出现在从数据库http 请求拿到的十六进制数据上:它们几乎总是字符串格式,不能直接参与算术运算。

  • 0x100 + 1257(合法)
  • "0x100" + 1 → PHP 会尝试类型转换,把 "0x100" 当作 0(因开头不是数字),结果是 1
  • 从 $_GET 拿到的 $_GET['color'] = "ff0000",必须用 hexdec($_GET['color']) 才能得到正确整数
  • filter_input(INPUT_GET, 'color', FILTER_SANITIZE_STRING) 后仍需手动 hexdec,过滤器不改数值含义

十六进制输出时 sprintf(“%x”) 和 dechex() 哪个更稳

dechex() 更直接,输入整数,输出小写十六进制字符串;sprintf("%x") 功能更强(支持补零、大小写控制),但参数类型更敏感——传非整数可能静默转成 0 或触发警告。

例如 sprintf("%x", "255") 在某些 PHP 版本里会返回 "0"(字符串转整失败),而 dechex("255") 会先强制类型转换,结果是 "ff",行为更可预期。

  • 简单转小写:用 dechex(255)"ff"
  • 需要补零(如颜色值):sprintf("%06x", 65280)"00ff00"
  • 要大写:用 sprintf("%X", 65280)dechex() 没有大写选项
  • 输入不确定是否为整数时,先 (int)$val 再传给 sprintf,避免隐式转换陷阱

十六进制和十进制之间的转换本身不难,真正卡人的永远是数据来源的类型混杂——字符串还是整数、带前缀还是不带、长度是否超出 int 范围。盯住变量的真实类型,比记住函数名重要得多。

text=ZqhQzanResources