首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >创建atoi函数

创建atoi函数
EN

Stack Overflow用户
提问于 2013-04-18 01:56:40
回答 5查看 2.9K关注 0票数 4

我正在尝试创建我自己的atoi函数。使用以下代码,我得到的返回值为0。无论我如何改变函数中的number变量,我都会得到返回值。对修改代码有什么建议吗?

代码语言:javascript
复制
//my atoi function
int atoi_me(char *numstring)
{
    int number = 0;
    while((*numstring >= '0') && (*numstring <= '9'))
    {
        number = (number * 10) + (*numstring - '0');
        numstring++;
    }

    return number;
}

int main()
{
    char *number[MAXSIZE];
    int num;

    printf("Please enter a number:\n");
    scanf("%c", &number);
    num = atoi_me(*number);
    printf("%d", num);
    return 0;
}
EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2013-04-18 02:09:07

  1. 你声明的是一个char *数组,也就是一个字符串数组,而不是单个字符串。您可能需要:

char numberMAXSIZE;

  • Your scanf格式字符串错误。如果你想读取一个字符串,你应该使用%s%c只读取一个character.

  • Your参数是错误的-传递number本身(或者如果你喜欢的话,传递&number[0] ),而不是传递给atoi_me&number.

  • The参数是错误的。使用*number.

而不是number (或等效的&number[0])调用它

把所有这些放在一起,你应该有一个类似下面这样的main例程:

代码语言:javascript
复制
int main(void)
{
    char number[MAXSIZE];
    int num;
    printf("Please enter a number: ");
    scanf("%s", number);
    num = atoi_me(number);
    printf("%d\n", num);
    return 0;
} 

编者按:scanf行有一个潜在的缓冲区溢出。您最好使用像fgets(3)这样的函数,它可以很容易地防止这种问题。

传统上,atoi(3)还支持负数(具有前导-)和可选的前导+ (用于正数),但您的实现不会处理这些+

票数 8
EN

Stack Overflow用户

发布于 2013-04-18 02:11:09

正如我所想的,问题出在你的电话里。

将您的main更改为。

代码语言:javascript
复制
int main()
{
    char number[MAXSIZE];
    int num;

    printf("Please enter a number:\n");
    scanf("%s", number);
    num = atoi_me(number);
    printf("%d", num);
    return 0;
}

除此之外,使用scanf - http://c-faq.com/stdio/scanfprobs.html不是一个好主意。在这种情况下,您应该使用fgets

票数 1
EN

Stack Overflow用户

发布于 2013-04-18 02:32:08

这不是atoi_me()函数的问题,而是如何获得输入的问题。您的实现显示了您对scanf()工作原理的理解上的一些弱点。这本身不是问题,犯错毕竟是学习过程的一部分。

通常,先将输入收集到缓冲区中会更安全,因为来自标准输入的scanf()太依赖于程序的用户来精确地键入您期望的输入。在这种情况下,没有太大的危害,因为您只需要一行输入。但是,通常情况下,程序将处理多行输入,当出现错误时,scanf()可能会阻塞。因此,您可以使用类似下面的代码来获取您的输入行:

代码语言:javascript
复制
char line[MAXLINESIZE];

if (fgets(line, MAXLINESIZE, stdin) == 0) {
    fprintf(stderr, "no input was provided!\n");
    return 0;
}

正如在其他地方提到的,%c不是用于您正在收集的输入的错误格式说明符。因为您需要十进制数字,所以*scanf()系列有一个格式说明符,只允许您收集这些字符。

代码语言:javascript
复制
char number[MAXSIZE];

if (sscanf(line, " %[0-9]", number) != 1) {
    fprintf(stderr, "no number found in input: %s", line);
    return 0;
}

在这里,我使用通过fgets()检索到的line,并解析出包含数字的输入部分。前导空格使sscanf()跳过以数字开头的空格字符。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16066885

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档