CString类型转换成16进制数的问题

本文介绍两种将CString类型转换为十六进制的方法,包括使用StrToIntEx函数及strtol函数实现的具体步骤。

最近工作中 遇到CString到Byte十六进制间的互转,留个笔记下来:

 

 

一个CString类型的数要转换成16进制的数,但是除了类型发生改变之外,所见的数是一样的。

比如:一个CString类型的数

CString a(“53 4d”); 

 转换成16进制之后仍然是0x53,0x4d.两者的不同之处在于:a是一个字符串,0x55和0x66只不过是其内容。

 

方法一:

包含文件和库
#include <shlwapi.h>
#pragma comment(lib, "shlwapi.lib")

//StrToIntEx 每次最多只能转换一个最大32位的十六进制数


用法:
CString x = TEXT("0xAABBCCDD");
int o = 0;
::StrToIntEx(x.GetString(), STIF_SUPPORT_HEX, o);

这样o = 0xAABBCCDD

 

方法二:

 

CString a(“53 4d”); 

BYTE x[2];

 

x[0] = strtol(a.Left(2),NULL,16); //转换存储

x[1] = strtol(a.Right(2),NULL,16); //转换存储

 

### 将十六进制转换为十进制的方法 将十六进制数转换为十进制数的过程可以通过以下方式实现,具体方法如下: #### 方法一:手动计算法 确定十六进制数的每个位所代表的权值。从右往左,第一个位的权值为 \(16^0\),第二个位的权值为 \(16^1\),依此类推。将每个位上的十六进制数字乘以其对应的权值,并对所有乘积进行求和,即可得到十进制表示的结果[^1]。 例如,对于十六进制数 `1A3`: - 第一位 `3` 的权值为 \(16^0 = 1\),其值为 \(3 \times 1 = 3\) - 第二位 `A`(等于10)的权值为 \(16^1 = 16\),其值为 \(10 \times 16 = 160\) - 第三位 `1` 的权值为 \(16^2 = 256\),其值为 \(1 \times 256 = 256\) - 总和为 \(3 + 160 + 256 = 419\) #### 方法二:字符数组遍历法 将十六进制数存储到字符串数组中,依次遍历每个字符。根据进制转换公式计算出相应的十进制值。对于字母 `a` 到 `f` 或 `A` 到 `F`,可以使用字符的 ASCII 码减去对应的数值来计算[^2]。 例如,对于十六进制数 `1AF`: - 字符 `1` 对应的十进制值为 `1` - 字符 `A` 对应的十进制值为 `10` - 字符 `F` 对应的十进制值为 `15` - 根据权值计算总和为 \(1 \times 256 + 10 \times 16 + 15 \times 1 = 431\) #### 方法三:C++ 实现代码 以下是一个用 C++ 实现的十六进制转十进制的示例代码[^3]: ```cpp #include <iostream> #include <cmath> #include <cstring> using namespace std; int main(void) { char* arr = new char[9]; // 要给‘\0’留一位 cin >> arr; int n = strlen(arr); // 计算字符串长度 long long sum = 0; // 用long long防止结果过大 for (int i = 0; arr[i] != '\0'; i++) { int temp; switch (arr[i]) { case 'A': temp = 10; break; case 'B': temp = 11; break; case 'C': temp = 12; break; case 'D': temp = 13; break; case 'E': temp = 14; break; case 'F': temp = 15; break; default: temp = arr[i] - '0'; break; } sum += temp * pow(16, n - 1 - i); } cout << sum; return 0; } ``` #### 方法四:函数实现法 以下是另一种 C++ 函数实现的方式[^4]: ```cpp #include <cmath> #include <cassert> int hex_char_value(char c) { if(c >= '0' && c <= '9') return c - '0'; else if(c >= 'a' && c <= 'f') return (c - 'a' + 10); else if(c >= 'A' && c <= 'F') return (c - 'A' + 10); assert(0); return 0; } int hex_to_decimal(const char* szHex, int len) { int result = 0; for(int i = 0; i < len; i++) { result += (int)pow((float)16, (int)(len - i - 1)) * hex_char_value(szHex[i]); } return result; } ``` #### 方法五:字符串累加法 通过读取数组中的每个字符,并将其转化为数字,然后进行累加计算。注意字符串最后一位是 `\0`,需要跳过[^5]。 例如,对于十六进制数 `12F`: - 字符 `1` 转化为十进制值为 `1` - 字符 `2` 转化为十进制值为 `2` - 字符 `F` 转化为十进制值为 `15` - 根据权值计算总和为 \(1 \times 256 + 2 \times 16 + 15 \times 1 = 299\) ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值