几年之前学的C,现在重新学一学,基本从零开始,主要目标做一个基于链表的简易学生管理系统。完全为初学者,请各位批评指正。此次主要是学习极客学院的视频。
首先,因为太久没有用过C了,先写了一个小程序重温重温,下面为当时写的程序:
#include <stdio.h>
void sleep(int a);
void main()
{
while(1)
{
printf("hello world");
sleep(1000);
}
}
void sleep(int a)
{
int i;
int j;
for(j=0;j<a*100;j++)
{
for(i=0;i<2000;i++);
}
}
想要延时1ms,但具体空循环的数值有点不记得了,所以时间比较随缘,不过还是能成功运行的。
熟悉之后,正式开始啦。
先学习主函数的设计。
1.先是malloc()函数,注意这个函数在stdlib.h,而不是在一般用的stdio.h中。
功能:
在内存中分配size个字节存储空间,并返回指向被分配存储区起始地址的指针;如不能忽的需要的存储空间,返回空指针。
注意:当把返回值赋给具有某一特定数据类型的指针变量时,应该对返回值做强制类型转换。
例如:为100个字符动态分配内存
char *ptr
ptr=(char*)malloc(100);//其中使用了强制转换,转换为字符型
例如:分配一个新的链表结点
l=(Node*)malloc(sizeof(Node));//sizeof用来计算Node占用的内存单元数
2.其次是calloc()函数,原型在头文件stdlib.h中定义
功能:
分配n个具有size个字节的存储空间,并返回一个指向被分配内存起始地址的指针;如果没有足够的内存可供分配,则返回一个空指针。(相对于malloc()函数,这个可以分配多个)
调用方式:void free(void *ptr)
3.再其次是free()函数,原型在头文件stdlib.h中定义
功能:
释放由ptr指向的内存空间,并将它返回给堆。free函数无返回值。
注意:ptr是最近一次调用malloc函数或calloc函数时返回的值。
动态分配的存储单元在用完后一定要释放,否则内存会因为申请空间过多引起资源不足而故障。
调用方式:void free(void *ptr)
4.最后在主函数中调用menu_select()函数显示主功能菜单,并且在switch分支选择结构中调用各子函数实现对学生信息的插入、查询、显示、保存、删除以及加载等功能。
接着,下面为主程序函数:(从视频中摘抄的,最后会贴自己做的)
#include <stdio.h>
#include<stdlib.h>
#include<dos.h>
#include<string.h>
#include<conio.h>
#include<iostream>
int menu_select()
{
int i;
printf("\n\n\t ****************************STUDENT LIST****************************\n");
printf("\t}* 1.input record *|\n");
printf("\t}* 2.delete record *|\n");
printf("\t}* 3.list record *|\n");
printf("\t}* 4.search record *|\n");
printf("\t}* 5.save record *|\n");
printf("\t}* 6.load record *|\n");
printf("\t}* 7.quit *|\n");
printf("\n\n\t ********************************************************************\n");
do
{
printf("\n\tEnter your choice:");
scanf("%d",&i);//扫描函数,将扫描的值存入i中
}while(i<=0||i>7);//判断i值是否在1~7之间,否则继续要求输入
return i;
}
void main()
{
link l;
l=(Node*)malloc(sizeof(Node));
if(l!)
{
printf("\n allocate memory failure!");
return;
}
l->next=NULL;
while(1)
{
system("cls");
swtich(menu_select())
{
case 1:
input(l);
break;
case 2:
del(l);
break;
case 3:
list(l);
break;
case 4:
search(l);
break;
case 5:
save(l);
break;
case 6:
load(l);
break;
case 7:
exit(0);
}
}