0

我试图通过在 C++ WinAPI 中将每个字母的 int 值相加来将字符串转换为数字。所以在ASCII中;std::string "AA" 等于 130 (65+65)

字符串可以是 std::string 或 std::wstring。

为什么无论我输入什么字母,以下函数总是返回零值?它不应该返回字母的 ASCII 或 Unicode 整数值吗?

printf("TEST a: %d \n", _tstoi(_T("a")));
printf("TEST A: %d \n", _tstoi(_T("A")));
printf("TEST b: %d \n", _tstoi(_T("b")));

我的 VC++ 应用程序当前使用 Unicode,并且前面的代码为每个字母打印出零。我记得听说 Unicode 与 ASCII 字符串非常不同,你能弄清楚除了 Unicode 有一个大约 30,000 长的字符库而 ASCII 是 256(我认为?)之外,究竟有什么不同吗?

4

3 回答 3

3

msdn文章说:

“输入字符串是一个字符序列,可以解释为指定类型的数值。函数在第一个无法识别为数字一部分的字符处停止读取输入字符串。”

如果您使用包含实际数字的 unicode 字符串测试代码,您将看到正确的输出:

printf("TEST 1: %d \n", _tstoi(_T("1")));

输出:

TEST 1: 1

就像@Ylisar 所说, *toi 函数用于将数字值从字符串转换为整数变量。

以下代码将改为输出数字表示,但要注意 const 变量的指针表示。我已经留下了两个版本,所以你可以看到区别:

  printf("TEST 1: %d \n", _tstoi(_T("1")));
  printf("TEST a: %d \n", _tstoi(_T("a")));
  WCHAR* b(_T("b"));
  printf("TEST A: %d \n", _T("A"));
  printf("TEST b: %d \n", *b);

输出:

TEST 1: 1
TEST a: 0
TEST A: 13457492
TEST b: 98

在http://msdn.microsoft.com/en-us/library/yd5xkb5c%28v=vs.80%29.aspx查看更多信息

如果您想总结(累积)这些值,我建议您查看 STL 范围函数,它对这些事情有奇效。例如

#include <numeric>
#include <string>

printf("TEST a: %d \n", *_T("a")); // 97
printf("TEST b: %d \n", *_T("b")); // 98

wstring uString(_T("ba"));
int result = accumulate(uString.begin(), uString.end(), 0);
printf("TEST accumulated: %d \n", result);

结果:

TEST a: 97
TEST b: 98
TEST accumulated: 195

这样您就不必让 for 循环遍历所有值。范围函数真的很适合这样的东西。

更多信息请访问:http ://www.sgi.com/tech/stl/accumulate.html

于 2011-10-20T09:38:39.297 回答
1

*toi 系列函数将字符串表示形式转换为整数表示形式,即“10”变为 10。您实际上想要做的根本不是转换。将其更改为:

printf("TEST a: %d \n", _T('a'));
printf("测试 A: %d \n", _T('A'));
printf("测试 b: %d \n", _T('b'));

至于 unicode,底层表示取决于编码(例如非常流行的 UTF-8,将 LSB 与 ASCII 表映射)。

于 2011-10-20T09:29:13.500 回答
0

Ylisar 已经回答了第一个问题,为什么printf不能按预期工作。关于对字符的十六进制表示求和的另一个问题要复杂一些。使用 _tstoi() 函数从字符串到数值的转换只有在给定的字符串表示像“123”这样的数字被转换为 123 时才有效。你想要的是字符表示的总和。

如果 Unicode 代码点低于 0x7F (0...127),这只是 1 字节 UTF-8 表示的总和。但是,在使用 UNICODE 标志编译的 Windows 上,使用每个字符 2 字节表示。在调试器中运行以下代码将实现这一点。

// ASCII 1 Byte per character
const char* letterA = "A";
int sumOfLetterA = letterA[0] + letterA[0]; // gives 130

// 2 Bytes per character (Windows)
const wchar_t* letterB = TEXT("B");
int sumOfLetterB = letterB[0] + letterB[0]; // gives 132
于 2011-10-20T10:05:05.010 回答