ImageVerifierCode 换一换
格式:DOCX , 页数:23 ,大小:296.72KB ,
资源ID:688963      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-688963.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(《C++程序设计》课程实习课程设计说明书之超市商品信息管理系统.docx)为本站会员(b****1)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

《C++程序设计》课程实习课程设计说明书之超市商品信息管理系统.docx

1、C+程序设计课程实习课程设计说明书之超市商品信息管理系统超市商品信息管理系统C+程序设计课程设计说明书指导教师: XXX设计成员: 刘 X 王 X赵 X张 X学院:XXXXXXXXXXXXXXX学院班级:XXXX齐齐哈尔大学计算机中心二零零八年九月C+程序设计课程设计任务书适用专业:计算机科学与技术设计题目:超市商品信息管理系统一、已知技术参数或设计前提1、中小型超市一般会有上万件商品。2、每件商品需要记录商品名、条形码、类别、价格、出厂日期等商品的基本信息。3、除此之外,还需要记录商品的其他相关信息,如生产厂家、供货处代码、厂家网址、厂家电话等。4、超市商品的相关信息需要存储到文件系统中,同

2、时需要提供对信息的添加、编辑、删除等操作。5、超市管理员每天会记录购进的商品信息,核销过期的商品等。二、设计内容及要求1、使用链表结构操作数据,提供创建、插入、删除节点等操作。2、使用类和结构表示商品信息。3、实现商品信息的添加、编辑、删除等功能。4、实现以商品名进行查询和显示所有商品信息的功能。5、实现使用文本文件保存所有商品信息的存储功能。三、课程设计工作计划1、确定题目,成立设计小组,做用户需求分析(9月1日-9月5日)2、查阅资料,进行问题分析,制定方案,确定成员分工(9月5日-9月10日)3、根据方案编写程序并进行调试(9月10日-9月25日)4、撰写设计说明书,完成设计(9月25日

3、-10月1日)5、提交设计内容,答辩四、相关教材及参考书目1、C+语言基础教程.吕凤翥编著.清华大学出版社指导教师签字: 系 主 任签字: 年 月 日2、C+程序设计教程.钱能编著.清华大学出版社一、需求分析中小型超市采购的商品一般都成千上万件。对这些商品进行有效的管理必不可少。每件商品一般都需要记录商品名、条形码、类别、价格、出厂日期等商品的基本信息。除此之外,还需要记录商品的其他相关信息,如生产厂家、供货处代码、厂家网址、厂家电话等。超市商品的相关信息需要存储到文件系统中,一般都需要提供对商品信息的添加、编辑、删除等操作。超市管理员每天都会记录购进的商品信息,核销过期的商品等。为了巩固我们

4、所学的C+语言程序设计知识,也为了满足课程设计的要求,我们在对几个中小型超市进行调研的基础上,设计和实现一个小型的超市商品管理系统,提供商品系统的添加、删除、编辑等功能。同类系统多数使用结构体数组来操作数据,本系统使用链表结构操作数据,提高了数据处理的效率。二、系统总体设计 系统应该具有管理系统的基本功能,即对商品信息能够进行添加、删除、编辑等基本管理。除此之外,还要考虑安全问题,即对系统设置密码,进行访问控制。系统设置了相应的链表结果表示操作商品信息。为了便于系统调试,系统将商品信息存储于文本文件中。系统体系结构图2-1所示。图 2-1系统体系结构根据需求分析,系统应该包含添加商品信息、删除

5、商品信息、显示商品信息、查询商品信息、编辑商品信息、保存数据等6个主要功能模块。系统总体框架如图2-2所示。图 2-2系统功能框图三、模块功能实现根据系统功能分析,设计具体的类以实现系统功能。系统主要使用2个主要的类来实现系统功能:一个为Manage类,负责实现系统界面的控制机制;另一个为list类,即链表类,实现系统的数据处理功能。系统的主要类之间的关系如图3-1所示。图 3-1系统类之间的关系1、list链表类的设计与实现根据总体设计内容,本系统主要使用链表结构来操作数据,所以链表类的设计与实现为系统实现的核心。链表类中的主要数据成员head为nodetype节点类型的数据。nodetyp

6、e的具体结构为:typedef struct linknode char address100; /厂家地址 char birthday100; /出厂日期 struct scokk sc; /供货处代号 struct goods go; /单个商品信息 struct telephone te; /购货方式 bool flag; struct linknode* next; /指向节点的指针nodetype;此节点类型类一个自定义的结构体,其中有7个数据域,两个整型数组分别代表厂家地址和出厂日期;还有三个数据域,是嵌入的结构体类型,分别代表供货处代号、单个商品信息、购货方式,其商品信息结构体的

7、具体结构如下:struct goods char name100; /商品名 char type100 ; /类别 char authentication100; /商品认证 char company100; /公司名 char price50; /价格; 其他结构的详细信息请参考附录A:程序源代码。此节点类型的最后一个域是重要的指针域,用于存放指向下一个节点的指针。根据上面设计的链表结构和系统功能设计的内容,可以进一步规划链表类的主要功能如下:(1)添加节点将新添加的商品信息填充到新创建的节点中,然后插入到链表里。类的成员函数原型如下:nodetype* List:insertNode(in

8、t i);其中,整型参数i为节点序号;函数返回值为链表的节点指针。在此函数中,首先,定义h,p,s三个指向节点的指针,h为指向链表头的指针,p为查找节点时返回的指针,s为指向新生成的节点的指针;然后,使用malloc函数创建一个空的节点,即在堆空间创建一个nodetype类型的变量,将s指针指向此变量;判断是否是此链表的第一个节点,如果是,则s所指节点为链表的头节点,并将h指针指向链表头节点;如果不是,则需要查找节点的插入位置,根据函数参数i调用intFindNode函数查找插入位置,并将返回的位置指针复制给p;如果p所指向的值存在,则将创建的s节点插入,否则,显示i值错误。一般插入节点的方法

9、是使用下面两条语句:s-next=p-next;/ s节点的next指针指向p节点的下一个节点p-next=s;/p的next指针指向s节点函数最后,将h指向链表的头节点,并返回新创建的节点s的地址。函数的程序流程图如图3-1所示。图 3-1 插入节点流程图(2)显示节点信息在系统中,需要显示所有的商品名信息、一件商品的所有信息等,这些都需要显示节点保存的相应信息。显示所有商品名,就是显示节点中的商品域中的商品名信息,它显示的是节点的一部分信息。显示所有的商品名的成员函数原型如下:void List:dispNameAll();其函数功能是显示所有商品名,无参数,无返回值。其函数体的主要源代码

10、如下所示:void List:dispNameAll() nodetype* p=head; cout 现有的商品: endl; if(p=NULL) cout 没有任何商品数据endl; while(p!=NULL) cout 商品名: go.namenext; 在函数体中主要利用while循环遍历访问整个链表,p=p-next;语句主要功能是指向节点的指针不断下移,以访问所有的节点。显示一件商品的所有信息使用的成员函数原型为:void List:dispOneNode(nodetype* p);函数的主要功能是显示一件商品的所有信息,参数p为指向节点的指针,无返回值。函数通过参数接收指向节

11、点的指针p,通过p访问其所指向的节点,并显示节点的所有信息(包括商品的基本信息,如商品名、价格等)。函数体的主要代码如下:void List:dispOneNode(nodetype* p) if(p!=NULL) dispGoods(p); /显示一件商品的基本信息 dispScokk(p); /显示一件商品的供货站代码 dispTelephone(p); /显示一件商品的订货方式 (3)修改节点信息由于节点保存的信息较多,使用了嵌套的结构体保存数据,所以修改时,也需要按照相应的结构进行修改。可以修改商品的基本信息、商品的供货站代码和商品的订货方式。使用的成员函数原型如下:void edit

12、Goods(nodetype* p); /编辑单个商品说明信息void editScokk(nodetype* p); /编辑单个商品供货方式void editTelephone(nodetype* p); /编辑单个商品订货方式(4)查找定位节点在进行节点的插入和编辑时,往往都需要按照指定的条件进行信息节点的查找。可以通过商品名或节点序号进行节点的查找定位。成员函数的原型如下所示:nodetype* intFindNode(int i); /通过查找序号返回节点的指针 nodetype* strFindNode(char c); /通过查找商品名返回节点的指针int findByName(c

13、har c); /通过查找商品名返回节点的序号其中,商品名查找节点,并返回节点指针使用较多,函数的主体代码如下所示。nodetype* List:strFindNode(char c) nodetype* p=head; int j=1; strcat(c, n); /从外部读入的字符串末尾都带了一个换行符 /查找第 i 个节点并由 p 指向该节点 while( p!=NULL & !(checkString(c, p-go.name) j+; p=p-next; return p;此函数主要通过p指针的移动,并比较p所指向的节点中的商品名与给定的查找商品名是否一致,如果相同则找到,否则,继续

14、移动p指针指向下一个节点继续比较,直到p指向链表尾(p为NULL)。(5)删除节点删除节点操作是一个常用的操作。一般需要先找到要删除的节点,然后,将其从链表中删除。由于节点是使用malloc函数生成的动态变量,所以,应该使用delete系统函数将其删除。删除后还需要保存链表的连接性,即删除链表中的指定节点时,需要如图3-2所示的一些后继的处理步骤。图 3-2节点删除的处理步骤删除节点的成员函数如下所示:void List:deleteNode(int i) nodetype *h=head, *p=head, *s; int j=1; if(i=1) /删除第一个节点 h=h-next; de

15、lete(p); else p=intFindNode(i-1); /查找第 i-1 个节点,p 指向这个节点 if(p!=NULL & p-next!=NULL) s=p-next; /s指向要删除的节点 p-next=s-next; delete(s); else cout输入的 i 值不正确endl; head=h;(6)创建链表与其他成员函数功能实现 略,详细内容请参看课程设计提交的源代码2、Manage类的设计与实现Manage类的主要功能是负责显示系统的主菜单和进行界面控制。其主要类结构如下:class Manage List L1; /存储结构public: void welco

16、me(); /登录页面,密码控制 void Loop(); /主循环 void display(); /显示菜单;其中,L1为List链表类的对象,是执行系统功能的核心部分。void Manage:Loop()成员函数主要负责进行界面控制。Loop函数首先,进行系统初始化,包括创建List类的实例对象L1;定义字符数组ch接收用户输入的数字,并执行相应功能;定义两个指向节点的指针*p, *head,其中p为指向普通节点的指针,head为指向链表头节点的指针;定义整型变量i存放节点的序号;从外部文件读入数据创建链表,p指向链表的头节;并让head指向头节点;显示系统主菜单等。这些步骤使系统得到初

17、始化。Loop函数体的程序流程图如图3-3所示。图 3-3 Loop函数程序流程图3、主函数的实现 在完成了上面两个主要类的基础上完成主函数。在主函数中创建Manage类的一个实例Goods,并调用Manage类中的Welcome成员函数,显示程序界面,并进行访问控制。main函数的主要代码如下:void main() Manage Goods; Goods.welcome();/显示程序欢迎界面四、系统的软硬件环境1、软件环境系统可以运行在Windows XP/200X等操作系统上。系统编辑编译环境为Visual C+ 6.0。2硬件环境本系统在计算中心实验室的计算机上编辑测试。测试用计算机

18、的主要配置是CPU 2.4GHz,256M内存,80G硬盘。本系统可以运行在使用Windows操作系统的品牌机或兼容机上,具有80486,50MHz以上的处理器都可以运行本管理系统。五、系统的使用说明系统在完成后进行了详细的软件功能测试。本系统可以完成对超市商品信息的添加、删除、显示、编辑等功能。软件的使用步骤如下:1、在课程设计的光盘中的“超市商品管理系统源代码”文件夹中找到“Debug”文件夹,在里面运行GoodsManage.exe可执行文件。系统会弹出如图所示的系统程序登陆界面,输入正确的密码(默认密码为“admin”)后可以进入到程序主界面。图 5-1 系统登陆界面2、在主程序界面中

19、,用户可以根据界面中的功能提示,输入相应的0-7的数字符号,执行相应的功能。主程序界面如图5-2所示。图 5-2 系统主功能菜单界面3、在主菜单程序界面中用户如果输入1,并按回车键,则会进入到添加商品信息的程序界面中,如图5-3所示。在这个界面中,会提示输入商品信息,如输入商品名、商品类别、出厂日期、商品认证、公司名、价格、厂址、条形码、购货网址、厂家电话等相关信息。录入时,以回车为每一项的结束符。图 5-3 添加商品信息界面4、如果用户在主程序界面中,输入2则会进入到删除商品信息界面里。在这个界面中,会显示已经存储在系统中的相关产品信息,主要是显示商品的名称。用户可以查看后,确定自己要删除的

20、信息,并输入要删除的商品的名称,以删除相应的商品。程序界面如图5-4所示。图 5-4 删除商品程序界面5、如果用户在主程序界面中输入4、可以查询商品信息,如图5-5所示。图 5-5 查询商品信息程序界面六、结束语 超市商品管理系统使用了链表类结构和面向对象的编成方法,有效地提高了商品信息的管理效率和程序代码的复用率以及程序的可维护性与扩展性。本小组成员通过一个多月的努力,从进入超市进行调研到系统设计并编写程序源代码以及系统编译测试,每个小组成员分工协作、共同努力圆满地完成了此次课程设计任务。系统的总体设计和主函数部分以及程序的汇总调试由组长刘X完成;list链表类的插入、删除和显示功能的设计与

21、实现由小组成员王X完成;list类的其余部分如节点的查找和创建的设计与实现由小组成员赵X完成;Manage类的设计与实现由小组成员张X完成。通过本次课程设计,小组成员较好地掌握了链表的使用方法和面向对象程序设计的基本技能,为将来的深入学习打下了坚实的基础。由于时间关系本系统还不是很完善,有些地方还需要改进。比如数据存储使用的是文本文件。这个系统也仅仅是一个利用链表类操作的基本系统,也希望以后能根据实际情况进一步的完善其功能,使其不但能满足课程设计的要求,还能有一定的实用价值。在整个的课程设计过程中,小组得到了其他各组同学和指导教师的帮助,这些帮助使我们克服了课程设计过程中的遇到的一些困难。在此

22、表示衷心感谢。七、参考文献1C+语言基础教程.吕凤翥编著.清华大学出版社2C+程序设计教程.钱能编著.清华大学出版社3456http:/www.china-789附录A:程序源代码文件名:main.cpp#include Manage.h/*/* 模块功能:主函数程序入口 */* 全局变量:无 */* 创建人:XXX */* 创建日期:XXXX年XX月XX日 */*/void main() Manage Goods; Goods.welcome();/显示程序欢迎界面文件名:Manage.h#include #include /strcpy(): 字符串复制#include /system(c

23、ls)#include /文件操作(写文件)#include list.h /创建类 List 的对象和节点指针/*/* 类功能:程序界面显示、密码控制、菜单显示、循环控制 */* 全局变量:无 */* 创建人:XXX */* 创建日期:XXXX年XX月XX日 */*/class Manage List L1; /存储结构public: void welcome(); /登录页面 void Loop(); /主循环 void display(); /显示菜单 ;文件名:list.h#include #include #include /字符串处理#include /文件操作(读文件)#incl

24、ude /system(cls)/*/* 类功能:操作链表,包括添加、删除、编辑节点等操作 */* 全局变量:无 */* 创建人:XXX */* 创建日期:XXXX年XX月XX日 */*/厂家地址struct address char country100; /国家 char city100; /城市 char street100; /街道;/购货方式struct telephone char WebSite50; /厂家网址 char FactoryTele30; /厂家电话 char DeliverTele30; /供货处电话;/商品信息struct goods char name100;

25、 /商品名 char type100 ; /类别 char authentication100; /商品认证 char company100; /公司名 char price50; /价格; /供货处代号struct scokk char num50; /条形码 char jialefu50; /家乐福 char woerma50; /沃尔玛 char suguo50; /苏果 char bailian50; /白莲;/定义节点的类型typedef struct linknode char address100; /地址 char birthday100; /出厂日期 struct scokk

26、 sc; /供货处代号 struct goods go; /单个商品信息 struct telephone te; /购货方式 bool flag; struct linknode* next; /指向节点的指针nodetype;/链表类class List nodetype *head;public: List(); List:List(); linknode* createList(int n); /创建链表 int ListLen(); /返回链表长度 nodetype* intFindNode(int i); /通过查找序号返回节点的指针 nodetype* strFindNode(char c); /通过查找商品名返回节点的指针 int findByName(char c); /通过查找商品名返回节点的序号 nodetype* insertNode(int i); /插入节点 void deleteNode(int i); /删除节点,删除第 i 个节点 nodetype* loadList(); /初始化:从外部读入数据 void readfromFile(F

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2