图书管理管理系统语言程序设计书.doc
文本预览下载声明
图书管理管理系统语言程序设计书
1、问题定义
图书信息包括:编号、书名、作者名、分类号、出版单位、出版时间、库存数量,价格等。 试设计一图书信息管理系统,使之能提供以下功能: (1)系统以菜单方式工作 (2)图书信息录入功能(图书信息用文件保存) (3)图书信息浏览功能 (4)图书信息查询功能 查询方式:可以按书名,按作者名,按出版单位,按出版时间进行查询。 (5)图书信息的删除与修改
在问题定义阶段要考虑题目的可行性和需求分析,接下来进入开发阶段,完成系统设计和系统实现的任务。
2、系统设计
2.1 总体设计
采用模块化的程序设计方法,即将较大的任务按照一定的原则分为一个个较小的任务,然后分别设计各个小任务。需要注意的是划分出来的模块应该相对独立但又相关,且容易理解。可以用模块化层次结构图(即模块图)来分析其任务的划分,一般从上到下进行,最上面一层是主模块,下面各层是其上一层模块的逐步细化描述。
图2.1 图书管理系统功能模块图
本图书管理系统要求采用单链表实现,如图2.1所示,它由如下四大功能模块组成:
借书模块。通过输入读者的编号和图书的编号,查找到要该借的书,完成借书这一项任务
还书模块。通过输入读者的编号和图书的编号,查找到要该还的书,完成还书这一项任务
图书维护模块。完成对图书信息的维护。在此图书管理系统中,它实现了对图书信息的新曾、更改、删除、查找和显示操作,并将追加后的数据存入源数据文件。
读者维护模块。一是实现对读者记录的存盘,即将读者信息写入数据文件中;
2.2 详细设计
2.2.1 借书模块
通过输入读者的信息和要借的书的编号。系统显示相应的内容,若该文件中没有数据,系统会提示单链表为空,没有任何读者记录或图书操作,此时,用户应选择调用create()函数,进行读者记录的输入,即完成在单链表1中添加记录的操作。值得一提的是,这里的字符串和数值的输入分别采用了函数来实现,在函数中完成输入数据任务,并对数据进行条件判断,直到满足条件为止,这样一来,大大减少了代码的重复和冗余,符合模块化程序设计的特点。
2.2.2 还书模块
还书模块主要实现了在单链表中按读者和图书的编号查找满足相关条件的借书记录。在用户选择4,调用查询函数search()中,为指向保存了读者信息的单链表的首地址的指针变量。为了遵循模块化编程的原则,我们将在单链表中进行的指针定位操作,设计一个
int retbook(int bookid)
{
for(int i=0;iMaxbor;i++)
{
if(borbook[i]==bookid)
{
borbook[i]=0;
return 1;
}
}
return 0;
}
//读出读者信息
void disp()
{
cout setw(5) no setw(10) name借书编号:[;
for(int i=0;iMaxbor;i++)
if(borbook[i]!=0)
cout borbook[i] |;
cout ]endl;
}
};
若没有该记录,则显示无此记录,返回到上一操作。
图书维护模块
此模块主要实现了对图书记录的新增、更改、删除、查找和显示操作。因为图书记录是以单链表的结构形式存储的,所以这些操作都在单链表中完成。下面分别介绍着4个功能模块。
①新增记录。该操作需要对单链表中目标节点的数据域中的值进行追加新增要输入图书的编号和书名,
int addbook(int n,char *na)
{
Book *p=query(n);
if (NULL==p)
{
top++;
book[top].addbook(n,na);
return 1;
}
return 0;
}
②更改系统。该操作可以将原本错误的图书记录更改,将之改为正确的记录。首先输入原来的记录的图书的编号,在此之后输入新的记录的书名。
③删除系统。该操作可以将原本记录得图书信息,在不用之后选择将此删除的一种方法,在弹出的窗口输入原来的图书的编号,就可以将之删除。
④ 查找系统。该操作可以帮助读者快速找到将要借的图书,只要输入图书的编号,如果有这本书,就将显示出。反之就会显示不存在。
Book *query(int bookid)
{
for (int i=0;i=top;i++)
if (book[i].getno()==bookid book[i].gettag()==0)
{
return book[i];
}
return NULL;
}
⑤显示系统。该操作可以显
显示全部