我不明白以下 C 代码的结果。
main()
{
char s[] = "AAA";
advanceString(s);
}
void advanceString(p[3])
{
int val = atoi(p);
printf("The atoi val is %d\n",val);
}
这里的atoi
值显示为 0,但我无法弄清楚确切的原因。根据我的理解,它应该是数组中每个值的十进制等值的总和?如果我错了,请纠正我。
atoi()
将整数的字符串表示形式转换为其值。它不会将任意字符转换为其十进制值。例如:
int main(void)
{
const char *string="12345";
printf("The value of %s is %d\n", string, atoi(string));
return 0;
}
标准 C 库中没有任何内容可以将“A”转换为 65 或“Z”转换为 90,您需要自己编写,特别是对于您期望作为输入的任何字符集。
既然您知道做什么了atoi()
,请不要用它来处理您想出的任何数字输入。你真的应该处理不是你所期望的输入。嗯,当我输入 65 而不是 A 时会发生什么?老师喜欢破坏东西。
atoi()
不做任何错误检查,这使得任何依赖它来转换任意输入的东西充其量都是脆弱的。相反,使用strtol()
(以 POSIX 为中心的示例):
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
int main(void)
{
static const char *input ="123abc";
char *garbage = NULL;
long value = 0;
errno = 0;
value = strtol(input, &garbage, 0);
switch (errno) {
case ERANGE:
printf("The data could not be represented.\n");
return 1;
// host-specific (GNU/Linux in my case)
case EINVAL:
printf("Unsupported base / radix.\n");
return 1;
}
printf("The value is %ld, leftover garbage in the string is %s\n",
// Again, host-specific, avoid trying to print NULL.
value, garbage == NULL ? "N/A" : garbage);
return 0;
}
运行时,这给出:
值为123,字符串中的剩余垃圾为abc
如果您不关心保存/检查垃圾,可以将第二个参数设置为NULL
. 没有必要free(garbage)
。另请注意,如果您将 0 作为第三个参数传递,则假定输入是十进制、十六进制或八进制表示的所需值。如果您需要 10 的基数,请使用 10 - 如果输入不符合您的预期,它将失败。
您还可以检查返回值以获取long int
可以处理的最大值和最小值。但是,如果返回任何一个以指示错误,errno
则设置。读者的一个练习是从*input
更改123abc
为abc123
。
检查退货很重要,因为您的示例显示了如果不这样做会发生什么。AbcDeFg 不是整数的字符串表示形式,您需要在函数中处理它。
对于您的实施,我能给您的最基本建议是一系列开关,例如:
// signed, since a return value of 0 is acceptable (NULL), -1
// means failure
int ascii_to_ascii_val(const char *in)
{
switch(in) {
// 64 other cases before 'A'
case 'A':
return 65;
// keep going from here
default:
return -1; // failure
}
..然后循环运行。
或者,预填充查找函数可以作用域(更好)的字典。您不需要哈希,只需要一个键 -> 值存储,因为您提前知道它将包含什么,其中标准 ASCII 字符是键,它们对应的标识符是值。
它尝试将字符串转换为整数。由于 AAA 不能转换为整数,因此值为 0。尝试给它 42 或其他值。
如果无法执行有效转换,则返回零值。
读取atoi()
为 a 到 i(ASCII 到整数)。
atoi()
将表示十进制数的字符串转换为整数。
char s[] = "42";
int num = atoi(s); //The value of num is 42.
atoi
期望其参数是十进制(base-10)整数常量的字符串表示形式;AAA
不是有效的十进制整数常量,因此atoi
返回 0,因为它没有其他方法可以指示输入无效。
请注意,atoi
它将转换为不属于有效整数常量的第一个字符;换句话说,“123”和“123w”都将转换为123。
就像其他人说的那样,不要使用atoi
; 改为使用strtol
。