Go标准库encoding/hex包提供可靠Hex编解码能力,含EncodeToString/DecodeString等核心函数及预处理、批量操作技巧。

Go语言标准库的encoding/hex包提供了简洁可靠的Hex编码与解码能力,无需第三方依赖,适合处理密码学、网络协议、日志调试等场景。
基础编码:字节切片转Hex字符串
使用hex.EncodeToString()可将[]byte安全转为小写十六进制字符串。注意它不修改原数据,返回全新字符串。
- 输入必须是字节切片(如
[]byte("hello")),不能直接传字符串(需先转[]byte(s)) - 结果默认为小写(
"68656c6c6f"),如需大写可用strings.ToUpper()后处理 - 空切片会返回空字符串,不会panic
基础解码:Hex字符串转字节切片
用hex.DecodeString()将合法Hex字符串还原为原始字节。该函数返回[]byte和error,务必检查错误。
- 字符串长度必须为偶数,否则返回
encoding/hex: odd length hex string - 只接受
0-9、a-f、A-F字符,含空格或中文会报错 - 支持大小写混合,例如
"aB3F"能正确解码
处理非标准格式:带前缀或分隔符的Hex串
实际中常遇到"0xdeadbeef"或"ab:cd:ef"这类格式,需预处理再解码。
立即学习“go语言免费学习笔记(深入)”;
- 去掉
"0x"前缀:strings.TrimPrefix(s, "0x") - 移除冒号分隔符:
strings.ReplaceAll(s, ":", "") - 统一转小写(可选):
strings.ToLower(s),提升容错性 - 再调用
hex.DecodeString()即可
高效批量操作:避免重复内存分配
对大量数据编解码时,可用hex.Encode()和hex.Decode()配合预分配字节切片,减少GC压力。
-
hex.Encode(dst, src):把src编码到已分配的dst中(len(dst) == 2*len(src)) -
hex.Decode(dst, src):把src解码到dst(len(dst) == len(src)/2) - 适合循环处理、流式解析等性能敏感场景
基本上就这些。标准库够用、接口清晰、错误明确,掌握这几个核心函数和常见预处理方式,就能覆盖绝大多数Hex编解码需求。










