我有以下程序
#include <stdio.h>
#include "dbg.h"
#define MAX_DATA 100
typedef enum EyeColor{
BLUE_EYES, GREEN_EYES, BROWN_EYES, BLACK_EYES, OTHER_EYES
} EyeColor;
const char *EYE_COLOR_NAMES[] = {
"Blue", "Green", "Brown", "Black", "Other"
};
typedef struct Person {
int age;
char first_name[MAX_DATA];
char last_name[MAX_DATA];
EyeColor eyes;
float income;
} Person;
int main(int argc, char *argv[]){
Person you = {.age = 0};
int i = 0;
char *in = NULL;
printf("What's your First Name? ");
in = fgets(you.first_name, MAX_DATA-1, stdin); //fgets is much better
check(in != NULL, "Failed to read first name.");
printf("What's your Last Name? ");
in = fgets(you.last_name, MAX_DATA-1, stdin);
check(in != NULL, "Failed to read last name.");
printf("How old are you? ");
int rc = fscanf(stdin, "%d", &you.age);
check(rc > 0, "You have to enter a number.");
printf("What color are your eyes:\n");
for(i = 0; i <= OTHER_EYES; i++) {
printf("%d) %s\n", i+1, EYE_COLOR_NAMES[i]);
}
printf("> ");
int eyes = -1;
rc = fscanf(stdin, "%d", &eyes);
check(rc > 0, "You have to enter a number.");
you.eyes = eyes - 1;
//check(you.eyes <= OTHER_EYES && you.eyes >= 0, "Do it right, that's not an option."); // if you dont check this, seg fault can happen because of ...
printf("How much do you make an hour? ");
rc = fscanf(stdin, "%f", &you.income);
check(rc > 0, "Enter a floating point number.");
printf("------ RESULTS ------\n ");
printf("First Name: %s", you.first_name);
printf("Last Name: %s", you.last_name);
printf("Age: %d\n", you.age);
printf("Eyes: %s\n", EYE_COLOR_NAMES[you.eyes]);
printf("Income: %f\n", you.income);
return 0;
error:
return 1;
}
如果我跑: $。/ EX24
我给出以下输入:
What's your First Name? a
What's your Last Name? b
How old are you? 1
What color are your eyes:
1) Blue
2) Green
3) Brown
4) Black
5) Other
> 1000
How much do you make an hour? 1
------ RESULTS ------
First Name: a
Last Name: b
Age: 1
Segmentation fault (core dumped)
这段错误是如何发生的?难道enum在我的内存中分配int类型应该能够容纳1000吗?
编辑1:将一些文本格式化为代码。 编辑2:注释掉支票。
答案 0 :(得分:6)
枚举是否可以达到1000并不重要;你的数组没有1000个元素 打印出来没有1000 th 眼睛颜色。
这是你应该构建的测试用例:
#include <iostream>
const char* EYE_COLOR_NAMES[] = { "a", "b", "c", "d", "e" };
const int eyes = 1000;
int main()
{
std::cout << EYE_COLOR_NAMES[eyes] << '\n';
}
我会说这显然不起作用。
您已经在代码中对you.eyes
进行了范围检查,并且您已经发现只有在您进行范围检查时才会发生分段错误。因此,只需离开范围检查。