其实这问题比较离谱,大概就是在函数中创建char数组, 代码如下
char t[10];
char sex[2];
char tel[12];
void swapNode(mem* p1, mem* p2) {
float temp = p1->age;
p1->age = p2->age;
p2->age = temp;
temp = p1->money;
p1->money = p2->money;
p2->money = temp;
temp = p1->summoney;
p1->summoney = p2->summoney;
p2->summoney = temp;
temp = p1->cost;
p1->cost = p2->cost;
p2->cost = temp;
temp = p1->sumcost;
p1->sumcost = p2->sumcost;
p2->sumcost = temp;
strcpy(t, p1->name);
strcpy(p1->name, p2->name);
strcpy(p2->name, t);
strcpy(t, p1->id);
strcpy(p1->id, p2->id);
strcpy(p2->id, t);
strcpy(sex, p1->sex);
strcpy(p1->sex, p2->sex);
strcpy(p2->sex, sex);
strcpy(tel, p1->tel);
strcpy(p1->tel, p2->tel);
strcpy(p2->tel, tel);
}
写法很蠢,因为这是之前接单 用户给的代码,重构的话太麻烦了,只能将就着写,能完成功能就行。问题就在
char t[10];
char sex[2];
char tel[12];
这三行代码上,如果将三行代码放到函数内,会导致链表中当前节点的next指针被破坏,经过该函数交换后的节点都无法继续使用,估计是栈空间里创建char数组的时候把next指针所在的位置覆盖了,按理来说不应该出现这种问题。
解决办法也很简单,使用new或者malloc将数组分配到堆空间上或者是直接创建全局变量,也就是在函数外定义数组。