Go语言高效转换:字符串数组中的十六进制数据转为uint8数组
本文探讨Go语言中如何将存储于字符串数组中的十六进制数据高效转换为uint8
数组。 直接使用[]byte()
转换字符串会失败,因为这只会转换字符串的字面值,而非十六进制数值本身。
方法一:直接存储十六进制字节
最佳实践是避免复杂的转换,直接在字符串数组中存储十六进制字节的原始表示。 这样可以避免后续的解析工作,提高效率。
func main() { // 直接使用十六进制字面量创建字节数组,再转换为字符串 cardbill := []string{string([]byte{0x00, 0xb2, 0x01, 0x5c, 0x00}), string([]byte{0x00, 0xb2, 0x02, 0x5c, 0x00})} // 原始字节数组 original := []byte{0x00, 0xb2, 0x01, 0x5c, 0x00} // 转换回字节数组 converted, _ := hex.DecodeString(cardbill[0]) // 使用hex.DecodeString进行解码 fmt.Println("Original:", original) fmt.Println("Converted:", converted) }
这种方法利用Go语言的十六进制字面量直接创建字节数组,然后将其转换为字符串存储。读取时,使用hex.DecodeString
函数高效地将十六进制字符串解码回uint8
数组。
方法二:解析逗号分隔的十六进制字符串
如果数据已存储为逗号分隔的十六进制字符串(例如:"0x00, 0xb2, 0x01, 0x5c, 0x00"),则需要解析字符串。 以下代码展示了如何处理这种情况:
import ( "fmt" "strconv" "strings" ) func main() { cardBill := []string{"0x00, 0xb2, 0x01, 0x5c, 0x00", "0x00, 0xb2, 0x02, 0x5c, 0x00"} original := []byte{0x00, 0xb2, 0x01, 0x5c, 0x00} var converted []byte for _, hexString := range strings.Split(cardBill[0], ",") { hexString = strings.TrimSpace(hexString) if len(hexString) > 2 && hexString[:2] == "0x" { hexString = hexString[2:] // Remove "0x" prefix if present } num, err := strconv.ParseUint(hexString, 16, 8) if err != nil { panic(err) } converted = append(converted, uint8(num)) } fmt.Println("Original:", original) fmt.Println("Converted:", converted) }
此方法使用strings.Split
函数分割字符串,strconv.ParseUint
将十六进制字符串转换为uint64
,再转换为uint8
并添加到uint8
数组中。 代码还加入了错误处理和对"0x"前缀的处理,增强了健壮性。
总结
方法一更简洁高效,推荐优先使用。 方法二适用于已有的逗号分隔十六进制字符串数据,需要额外的解析步骤。 选择哪种方法取决于数据的存储方式和项目需求。 记住始终进行错误处理以确保代码的稳定性。