请指出下面代码中的错误 static char *student[MAX_STUDENT_NUM] = (NULL); int find_student_id_by_name (const char *name) { int i = 0; for (i = 0; student[i] != NULL && i < MAX_STUDENT_NUM; ++i){ if (0 == strcmp(student[i], name)) return i; } return -ERR_NOT_FIND; }
时间: 2024-01-31 07:02:34 浏览: 61
代码中有如下错误:
1. 第一行中,应该使用数组来存储学生的姓名,而不是指针数组。应该将 char *student[MAX_STUDENT_NUM] 改为 char student[MAX_STUDENT_NUM][MAX_NAME_LEN]。
2. 第一行中,赋值语句中不应该有括号,应该改为等号。
3. 第六行中,应该先判断 i 是否小于 MAX_STUDENT_NUM,再判断 student[i] 是否为 NULL,否则可能会出现数组越界的问题。
4. 第七行中,strcmp 函数返回值为 0 表示两个字符串相等,应该将判断条件改为 if (strcmp(student[i], name) == 0)。
5. 第九行中,-ERR_NOT_FIND 应该改为 -ERR_STUDENT_NOT_FOUND。
修改后的代码如下:
```
static char student[MAX_STUDENT_NUM][MAX_NAME_LEN] = {0};
int find_student_id_by_name(const char *name) {
int i = 0;
for (i = 0; i < MAX_STUDENT_NUM && student[i][0] != '\0'; ++i) {
if (strcmp(student[i], name) == 0) {
return i;
}
}
return -ERR_STUDENT_NOT_FOUND;
}
```
相关问题
8.请指出下面代码中的错误 static char *student[MAX_STUDENT_NUM] = (NULL); int find_student_id_by_name (const char *name) { int i = 0; for (i = 0; student[i] != NULL && i < MAX_STUDENT_NUM; ++i){ if (0 == strcmp(student[i], name)) return i; } return -ERR_NOT_FIND; }
下面是代码错误的解释和修正建议:
1. static char *student[MAX_STUDENT_NUM] = (NULL);
这行代码中,使用了括号将 NULL 括起来,这是错误的。正确的写法是:
static char *student[MAX_STUDENT_NUM] = {NULL};
2. 在函数 find_student_id_by_name 中,变量 ERR_NOT_FIND 没有定义,应该先定义它。
3. 在比较字符串时,应该使用 strcmp 函数,而不是 == 进行比较。
下面是修正后的代码:
#define ERR_NOT_FIND -1
static char *student[MAX_STUDENT_NUM] = {NULL};
int find_student_id_by_name(const char *name) {
int i = 0;
for (i = 0; student[i] != NULL && i < MAX_STUDENT_NUM; ++i) {
if (0 == strcmp(student[i], name)) {
return i;
}
}
return ERR_NOT_FIND;
}
8.请指出下面代码中的错误 static char *student[MAX_STUDENT_NUM] = {NULL}; int find_student_id_by_name (const char *name) { int i = 0; for (i = 0; student[i] != NULL && i < MAX_STUDENT_NUM; ++i){ if (0 == strcmp(student[i], name)) return i; } return -ERR_NOT_FIND; }
代码中存在两个错误:
1. `student[i]` 是一个 `char*` 类型的指针,应该与 `name` 进行比较,而不是与 `0` 进行比较。
2. 在比较 `student[i]` 和 `name` 之前,应该先判断 `student[i]` 是否为 NULL,否则可能会出现空指针异常。
下面是修改后的代码:
```
static char *student[MAX_STUDENT_NUM] = {NULL};
int find_student_id_by_name (const char *name) {
int i = 0;
for (i = 0; i < MAX_STUDENT_NUM && student[i] != NULL; ++i) {
if (strcmp(student[i], name) == 0)
return i;
}
return -ERR_NOT_FIND;
}
```
其中,`strcmp` 函数用于比较两个字符串是否相等。
阅读全文