1、精品文档 C语言程序设计 实验报告题 目: 图书管理管理系统院 系: 信息科技学院专 业: 姓 名: 学 号: 指导教师: 杨呈勇 日 期: 09-09-181 问题定义 .32 系统设计 321 总体设计422 详细设计42.2.1 借书模块 42.2.2 图书维护 5 新增记录 5 更改系统. 6删除系统 6 查找系统. 6 显示系统 . 73 系统实现 103.1 编码 83.1.1 程序预处理 .93.1.2 主函数main() .94 系统维护 165 归纳总结 165.1 开发经验 165.2 实训中遇到的问题及解决方法 165.3 设计中的不足之处165.4 感想和心得体会 16
2、图书管理系统 本题目设计目的是训练学生的基本编程能力,了解管理信息系统的开发流程,熟悉C语言的文件和单链表的各种基本操作。本程序中涉及结构体、单链表、文件及各种语句的运用如for();switch();if.else等方面的知识。通过本程序的训练,使学生能对C语言的文件操作有一个更深刻的了解,初步掌握链表的一些结构及构成。掌握利用单链表存储结构实现对学生成绩管理的原理,为进一步开发出高质量的管理信息系统打下坚实的基础。1、问题定义图书信息包括:编号、书名、作者名、分类号、出版单位、出版时间、库存数量,价格等。 试设计一图书信息管理系统,使之能提供以下功能: (1)系统以菜单方式工作 (2)图书
3、信息录入功能(图书信息用文件保存) (3)图书信息浏览功能 (4)图书信息查询功能 查询方式:可以按书名,按作者名,按出版单位,按出版时间进行查询。 (5)图书信息的删除与修改在问题定义阶段要考虑题目的可行性和需求分析,接下来进入开发阶段,完成系统设计和系统实现的任务。2、系统设计21 总体设计采用模块化的程序设计方法,即将较大的任务按照一定的原则分为一个个较小的任务,然后分别设计各个小任务。需要注意的是划分出来的模块应该相对独立但又相关,且容易理解。可以用模块化层次结构图(即模块图)来分析其任务的划分,一般从上到下进行,最上面一层是主模块,下面各层是其上一层模块的逐步细化描述。 图2.1 图
4、书管理系统功能模块图本图书管理系统要求采用单链表实现,如图2.1所示,它由如下四大功能模块组成:l 借书模块。通过输入读者的编号和图书的编号,查找到要该借的书,完成借书这一项任务l 还书模块。通过输入读者的编号和图书的编号,查找到要该还的书,完成还书这一项任务l 图书维护模块。完成对图书信息的维护。在此图书管理系统中,它实现了对图书信息的新曾、更改、删除、查找和显示操作,并将追加后的数据存入源数据文件。l 读者维护模块。一是实现对读者记录的存盘,即将读者信息写入数据文件中; 22 详细设计2.2.1 借书模块通过输入读者的信息和要借的书的编号。系统显示相应的内容,若该文件中没有数据,系统会提示
5、单链表为空,没有任何读者记录或图书操作,此时,用户应选择调用create()函数,进行读者记录的输入,即完成在单链表1中添加记录的操作。值得一提的是,这里的字符串和数值的输入分别采用了函数来实现,在函数中完成输入数据任务,并对数据进行条件判断,直到满足条件为止,这样一来,大大减少了代码的重复和冗余,符合模块化程序设计的特点。2.2.2 还书模块还书模块主要实现了在单链表中按读者和图书的编号查找满足相关条件的借书记录。在用户选择4,调用查询函数search()中,为指向保存了读者信息的单链表的首地址的指针变量。为了遵循模块化编程的原则,我们将在单链表中进行的指针定位操作,设计一个int retb
6、ook(int bookid) for(int i=0;iMaxbor;i+) if(borbooki=bookid) borbooki=0; return 1; return 0; /读出读者信息 void disp() cout setw(5) no setw(10) name借书编号:; for(int i=0;iMaxbor;i+) if(borbooki!=0) cout borbooki |; cout endl; ; 若没有该记录,则显示无此记录,返回到上一操作。2.2.3 图书维护模块此模块主要实现了对图书记录的新增、更改、删除、查找和显示操作。因为图书记录是以单链表的结构形式
7、存储的,所以这些操作都在单链表中完成。下面分别介绍着4个功能模块。新增记录。该操作需要对单链表中目标节点的数据域中的值进行追加新增要输入图书的编号和书名,int addbook(int n,char *na) Book *p=query(n); if (NULL=p) top+; booktop.addbook(n,na); return 1; return 0; 更改系统。该操作可以将原本错误的图书记录更改,将之改为正确的记录。首先输入原来的记录的图书的编号,在此之后输入新的记录的书名。删除系统。该操作可以将原本记录得图书信息,在不用之后选择将此删除的一种方法,在弹出的窗口输入原来的图书的编
8、号,就可以将之删除。 查找系统。该操作可以帮助读者快速找到将要借的图书,只要输入图书的编号,如果有这本书,就将显示出。反之就会显示不存在。Book *query(int bookid) for (int i=0;i=top;i+) if (booki.getno()=bookid &booki.gettag()=0) return &booki; return NULL; 显示系统。该操作可以显示出图书现在的信息。cout 输入图书编号: bookid; cout 输入图书书名: bname; addbook(bookid,bname); break; case 2: cout 输入图书编号:
9、 bookid; b=query(bookid); if (b=NULL) cout 该图书不存在 endl; break; cout 输入新的书名: bname; b-setname(bname); break; case 3: cout 读入图书编号: bookid; b=query(bookid); if (b=NULL) cout 该图书不存在 delbook(); break; case 4: cout 读入图书编号: bookid; b=query(bookid); if (b=NULL) cout 该图书不存在disp(); break; case 5: disp(); brea
10、k; case 6: clear(); break; default:cout输入错误,请从新输入:; cout 输入图书编号: bookid; cout 输入图书书名: bname; addbook(bookid,bname); break; case 2: cout 输入图书编号: bookid; b=query(bookid); if (b=NULL) cout 该图书不存在 endl; break; cout 输入新的书名: bname; b-setname(bname); break; case 3: cout 读入图书编号: bookid; b=query(bookid); if
11、(b=NULL) cout 该图书不存在 delbook(); break; case 4: cout 读入图书编号: bookid; b=query(bookid); if (b=NULL) cout 该图书不存在disp(); break; case 5: disp(); break; case 6: clear(); break; default:cout输入错误,请从新输入:; cout 输入图书编号: bookid; cout 输入图书书名: bname; addbook(bookid,bname); break; case 2: cout 输入图书编号: bookid; b=que
12、ry(bookid); if (b=NULL) cout 该图书不存在 endl; break; cout 输入新的书名: bname; b-setname(bname); break; case 3: cout 读入图书编号: bookid; b=query(bookid); if (b=NULL) cout 该图书不存在 delbook(); break; case 4: cout 读入图书编号: bookid; b=query(bookid); if (b=NULL) cout 该图书不存在disp(); break; case 5: disp(); break; case 6: cle
13、ar(); break; default:cout输入错误,请从新输入:; 3、系统实现31 编码3.1.2 主函数main()include #include #include /输入/输出文件流类 #include using namespace std; /最多的读者 const int Maxr=100; /最多的图书 const int Maxb=100; /每位读者最多借五本书 const int Maxbor=5; /图书库类,实现对图书的维护,查找,删除等 class BDatabase private: /图书记录指针 int top; /图书记录 Book bookMaxb
14、; public: /构造函数,将book.txt读到book中 BDatabase() Book b; top=-1; fstream file(book.txt,ios:in); while (1) file.read(char *)&b,sizeof(b); if (!file) break; top+; booktop=b; file.close(); /全删 void clear() top=-1; /增加图书 int addbook(int n,char *na) Book *p=query(n); if (NULL=p) top+; booktop.addbook(n,na);
15、return 1; return 0; /查找图书 Book *query(int bookid) for (int i=0;i=top;i+) if (booki.getno()=bookid &booki.gettag()=0) return &booki; return NULL; /图书库维护 void bookdata(); void disp() for (int i=0;i=top;i+) if (booki.gettag()=0) booki.disp(); /析构函数,将book写到book.txt文件中 BDatabase() fstream file(book.txt,i
16、os:out); for (int i=0;i=top;i+) if (booki.gettag()=0) file.write(char *)&booki,sizeof(booki); file.close(); ; void BDatabase:bookdata() char choice; char bname40; int bookid; Book *b; while (choice!=0) cout nnnttt图 书 维 护 endlendl; couttt1 新 增n tt2 更 改ntt3 删 除ntt4 查 找ntt5 显 示ntt6 全 删ntt0 退 出 choice;
17、switch (choice) case 1: cout 输入图书编号: bookid; cout 输入图书书名: bname; addbook(bookid,bname); break; case 2: cout 输入图书编号: bookid; b=query(bookid); if (b=NULL) cout 该图书不存在 endl; break; cout 输入新的书名: bname; b-setname(bname); break; case 3: cout 读入图书编号: bookid; b=query(bookid); if (b=NULL) cout 该图书不存在 delbook
18、(); break; case 4: cout 读入图书编号: bookid; b=query(bookid); if (b=NULL) cout 该图书不存在disp(); break; case 5: disp(); break; case 6: clear(); break; default:cout输入错误,请从新输入:; /main() 函数的实现,程序的主界面的引导 int main() char choice; int bookid,readerid; RDatabase ReaderDB; Reader *r; BDatabase BookDB; Book *b; while(
19、choice!=0) cout endlendlttt 图 书 管 理 系 统nnn; cout ttt1 借 书nnttt2 还 书 nnttt3 图 书 维 护nnttt4 读 者 维 护nnttt0 离 开 choice; switch (choice) case 1: cout readerid; cout bookid; /按编号查找 r=ReaderDB.query(readerid); if (NULL=r) cout 不存在该读者,不能借书 endl; break; b=BookDB.query(bookid); if (b=NULL) cout 不存在该图书,不能借书borr
20、owbook()=0) cout 该图书已借出,不能借书borrowbook(b-getno(); break; case 2: coutreaderid; cout bookid; r=ReaderDB.query(readerid); if (r=NULL) cout 不存在该读者,不能还书 endl; break; b=BookDB.query(bookid); if (b=NULL) cout 不存在该图书,不能还书 retbook(); r-retbook(b-getno(); break; case 3: BookDB.bookdata(); break; case 4: Read
21、erDB.readerdata(); break; default:cout输入错误,请从新输入:; 4、系统维护经测试与调试确认软件无错时,开发就告一段落,这时可以交付软件供用户使用,但是在软件的使用过程中还会面临更加漫长的工作,即软件维护。一般维护的工作有:更改使用中发现的错误;为适应实际环境而对程序进行修改;为满足新的需求而对程序作必要的改进等等。5、归纳总结51 开发经验通过对本题目的开发,体会到要掌握以下几点内容。l 大程序的设计风格。按“自顶向下,逐步细化,模块化”的方法进行程序设计。l 编写主函数,并进行测试与调试。当被调函数又需要调用其他函数时,也要遵循逐步细化的原则。C语言提
22、供丰富的库函数,编程序时要善于使用库函数,避免不必要的劳动。l 定义函数时,应选好参数的个数和数据类型。l 文件使用方法。文件使用完毕后应及时关闭。52 实训中遇到的问题及解决方法在实训过程中,我遇到许多的问题,比如有些语句有语法错误,表达式不正确,或缺少或;等。或者是没有宏定义,申明某些变量。这些都比较容易解决。通过查阅课本和请教同学,在经过WIN-TV编译,知道哪有错误就改一下就行。比较严重的是,我的代码在求解平均成绩和总分时没有录入,且乱码。自已改了很久,也在网上查询但是都不行。最后在老师的帮助下及查阅有关资料,把代码改出来了。53 设计中尚存的不足之处关于这次的程序,也有挺多不足的地方
23、。首先,我觉得程序还不够完善,比如没有排序前和排序后的学生记录输出结果显示和有些程序功能没有满足所给题目要求及好几项都没有显示出学生具体的信息,甚至有些地方有点乱;其次,有些地方好像功能有点重复了,且编写的代码有重复;最后,就是该程序界面不够美观大方,有些文件不能链接。54 感想和心得体会通过这次实训,我感触甚深,要把所学的理论知识运用于解决实际问题不仅要付出艰辛的劳动,还得要有科学的方法和坚持不懈的努力。加上我们只是学了一个学期的c语言,我们所学的知识还不足以独立编写程序代码。但是我认为只要我们认真的去学去做,我们会受益非浅。这次实训让我进一步理解了“编程是什么”,“如何去编程”,“编程的目
24、的又是什么”,发现自己的知识竟是如此贫乏,顿时感到了压力的存在,从而也激发了我的学习热情。它会成为我今后不断进取、永不懈怠的动力。在整个实训过程中,老师给了我很大的帮助,使我由不了解怎样运用链表到逐渐懂得链表的结构及初步掌握链表结构。还重新复习了一些语句的使用,比如for(0;switch();if.elser();结构体的使用;枚举等。而且我能够坚持虚心的向老师以及同学请教问题。它使我明白了虚心好学的重要性,更让我懂得了如何跟老师同学去相处、去沟通。没有老师和同学们的无私帮助,我不可能圆满完成这次实训任务。非常感谢帮助过我的所有老师和同学们,在此,谨向他们一并表示感谢!我开始喜欢这个程序设计了,尤其觉得它是很有挑战性的,是对知识点扎实程度的考察,也是对个人能力的考察,还是对个人化毅力的考验。它让我明白做任何事都不应该轻易放弃。这样的课程设计,既有利于教学,又可以教会学生书本以外的很多知识。现在我对它越来越感兴趣,今后我会更加关注C语言程序,把C语言学好。希望老师以后多多指导,给予一定的帮助! 可修改