在大学里,我被问到我们的程序是否检测到从命令行参数输入的字符串是否是一个整数,但它没有检测到(./Program 3.7)。现在我想知道如何检测到这一点。因此输入例如 a atoi 检测到的无效,但输入例如 3.6 应该是无效的,但 atoi 会将其转换为整数。

#include <stdio.h>

int main(int argc, char *argv[]) {
    if (argc > 1) {
        int number = atoi(argv[1]);
        printf("okay\n");
    }
}

但当然,只有当 argv[1] 确实是一个整数时才应该打印。希望我的问题很清楚。非常感谢。

有帮助吗?

解决方案

看一看 strtol将

  

•若endptr不是NULL,与strtol()存储在* endptr第一无效字符的地址。如果没有数字可言,但是,与strtol()STR存储在* endptr原始值。 (因此,如果* STR上没有返回\0' but **endptr is \ 0' ,整个字符串是有效的。)

#include <stdio.h>

int main(int argc, char *argv[]) {
  if (argc > 1) {
    char* end;
    long number = strtol(argv[1], &end, 0);
    if (*end == '\0')
      printf("okay\n");
  }
}

其他提示

假设您想知道如何在代码中完成它(如果它确实是家庭作业,则可能),一种方法是考虑什么构成了字符串的整数。最有可能的是:

  • 可选符号 +/-。
  • 一个必需的数字。
  • 任意数量的可选数字(但要注意溢出)。
  • 字符串的末尾。

根据该规范,您可以编写一个函数来为您完成这项工作。

像这样的伪代码将是一个好的开始:

set sign to +1.
set gotdigit to false.
set accumulator to 0.
set index to 0.
if char[index] is '+':
    set index to index + 1.
else:
    if char[index] is '-':
        set sign to -1.
        set index to index + 1.
while char[index] not end-of-string:
    if char[index] not numeric:
        return error.
    set accumulator to accumulator * 10 + numeric value of char[index].
    catch overflow here and return error.
    set index to index + 1.
    set gotdigit to true.
if not gotdigit:
    return error.
return sign * accumulator.
int okay = argc>1 && *argv[1];
char* p = argv[1];
int sign = 1;
int value = 0;
if( *p=='-' ) p++, sign=-1;
else if( *p=='+' ) p++;
for( ; *p; p++ ) {
    if( *p>='0' && *p<='9' ) {
        value = 10*value + *p-'0';
    } else {
        okay = 0;
        break;
    }
}
if( okay ) {
    value *= sign;
    printf( "okay, value=%d\n", value );
}

编辑:允许 - 和+字符

您可能甚至压缩成一个致密的一个或两个衬垫此。或可能发现具有相同功能的库函数;)

EDIT2:只是为了好玩 - 它现在应该解析数

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top