0

我应该填写的代码很容易。

#define MAX_NAME_LEN 128
typedef struct {
 char name[MAX_NAME_LEN];
 unsigned long sid;
} Student;
/* return the name of student s */
const char* getName(const Student* s) {
 return s->name;
}
/* set the name of student s */
void setName(Student* s, const char* name) {
 /* fill me in */
}/* return the SID of student s */
unsigned long getStudentID(const Student* s) {
 /* fill me in */
}
/* set the SID of student s */
void setStudentID(Student* s, unsigned long sid) {
 /* fill me in */
}

但是它说以下函数中的逻辑错误是什么?

Student* makeDefault(void) {
 Student s;
 setName(&s, "John");
 setStudentID(&s, 12345678);
 return &s;
}

我没有看到任何问题。我测试了它。它工作正常。

是不是因为这应该是一个 void 函数并且不需要返回任何东西?

4

1 回答 1

0

您不能返回指向本地声明变量(Student s)的指针。返回后变量“s”会消失(变成垃圾)。

相反,您需要先分配一个学生。

你可能应该这样做:

void makeDefault(Student* pS) {
 setName( pS, "John");
 setStudentID( pS, 12345678);
}

然后让调用应用程序分配学生。

于 2013-02-15T08:28:29.320 回答