1.学生结构体定义的时候,要求使用枚举类型表示学生的性别,“male” and “female”,但是枚举类型不能输出,后来用if语句来解决这个问题。
例子:
if(xinbiemale)
printf(“male”);
2.程序运行时,释放链表的函数总是出现,Thread 1: signal SIGABRT,找了一些资料,好像是多次free造成的结果,但是释放链表不就是要多次free的吗?后面发现是free了原本为NULL的指针,检查了其他的函数发现在一些函数里面在最后我free了该函数的局部指针变量,我原本以为这是一个好习惯,但是那个指针当时正指向链表的某个节点,所以指针对应的节点也被free且置空,而return 的head里面已经储存了这一步操作,所以在销毁链表的时候会free到一个本来为NULL的指针。所以在处理链表的函数里面不要随便free指针和置空指针。
-----------------------------------------------------------------------------------------------------(2020-05-10)
链表排序(冒泡排序法)
交换节点而不是交换数据,因为数据项太多了。
struct StuLink *pre = NULL;
struct StuLink *p = NULL;
struct StuLink *tail=NULL;
while(list->next!=tail)
{
if(i1)
{
pre=list;
p=list->next;
while(p->next!=tail)
{
if(p->cjnext->cj)
{
pre->next=p->next;
p->next=pre->next->next;
pre->next->next=p;
}
else
p=p->next;
pre=pre->next;
}
tail=p;
}
很巧妙的一种方法,摘自https://www.cnblogs.com/orion7/p/7227627.html
-----------------------------------------------------------------------------------------------------(2020-05-12)