客户消费积分管理系统设计及实现课程设计

上传人:第*** 文档编号:62191795 上传时间:2018-12-18 格式:DOC 页数:22 大小:507.50KB
返回 下载 相关 举报
客户消费积分管理系统设计及实现课程设计_第1页
第1页 / 共22页
客户消费积分管理系统设计及实现课程设计_第2页
第2页 / 共22页
客户消费积分管理系统设计及实现课程设计_第3页
第3页 / 共22页
客户消费积分管理系统设计及实现课程设计_第4页
第4页 / 共22页
客户消费积分管理系统设计及实现课程设计_第5页
第5页 / 共22页
点击查看更多>>
资源描述

《客户消费积分管理系统设计及实现课程设计》由会员分享,可在线阅读,更多相关《客户消费积分管理系统设计及实现课程设计(22页珍藏版)》请在金锄头文库上搜索。

1、编号 课程设计报告20152016学年 第一学期客户消费积分管理系统的设计与实现The Design and Implementation of a Client Integral Management System实 习 类 别课程设计学 生 姓 名 李志莹专 业 软件工程学 号 140521329指 导 教 师刘丹、 何巍学 院计算机科学技术学院二一五年十二月 起 止 周1718周数2实习地点南研1213/1208/1201实验室课程设计目的:l 了解并掌握数据结构与算法的设计方法,具备初步的独立分析和设计能力;l 初步掌握软件开发过程的问题分析、系统设计、程序编码、测试等基本方法和技能;

2、l 提高综合运用所学的理论知识和方法独立分析和解决问题的能力;l 训练学生用系统的观点和软件开发一般规范进行软件开发,培养软件工作者所应具备的科学的工作方法和作风。课程设计要求:1、独立思考,独立完成:课程设计中各任务的设计和调试要求独立完成,遇到问题可以讨论,但不可以拷贝。2、做好上机准备:每次上机前,要事先编制好准备调试的程序,认真想好调试步骤和有关环境的设置方法,准备好有关的文件。3、实践设计以实际应用中的小型题目为主,要求学生独立完成或合作完成。要求学生能根据不同的题目类型选择一种或两种开发模式,完成从系统定义,指定开发计划,需求分析,设计,编码/测试,直至运行/维护的软件生存期的全过

3、程。完成课程设计题目客户消费积分管理系统的设计与实现进度安排及主要内容:第1次课:布置任务;第2次课:问题分析及解决方案确定;第3次课:形成编程思路;第4次课:使用具体语言实现算法;第5次课:上机调试程序;第6次课:编写课程设计报告;成绩:指导教师(签字)年 月 日一、概述1.1 设计主要完成的任务1.1.1 题目要求针对客户的消费情况,进行客户管理,根据客户的消费积分对客户实行不同程度的打折优惠。采用一定的存储结构进行客户信息的存储;对客户的信息可以进行修改、删除、添加;能够根据消费情况进行客户积分的累加;根据积分情况,对客户实行不同程度的打折优惠; 1.2 解决的主要问题1.2.1 采用何

4、种数据结构和编程语言实现客户抽象由于客户数目不定,所以采用链表结构实现客户的增删改查等基本操作,用C#窗体图形用户界面技术编写程序。本程序要运用链表对客户信息进行存储,首先对结点进行定义,采用C#泛型思想和接口建立单链表类,并实现单链表的基本操作,代码主要参考的是数据结构(C#语言版),但是在实际编写过程中略有调整。1.2.2 界面设计(1) 主界面:功能按钮导航;(2) 添加界面:添加新客户的信息;(3) 删除界面:按客户ID删除已有客户。(4) 修改界面:按客户ID修改已有客户信息。(5) 查找界面:按客户ID查找已有客户。(6) 显示界面:遍历显示表中所有的客户的所有信息。(7) 消费界

5、面:按客户ID对已有客户进行消费操作。1.2.3 数据结构中单链表的C#实现对于单链表的操作,主要用到两个类,一个是Node类,一个是List类。Node类主要是建立节点的类,这个类包含数据内容data和“指针”next用于指向下一个节点,实现单链表的连接。List类主要是进行对单链表的各种操作:v 初始化头节点为空的链表。v 求单链表的长度。v 清空单链表。v 判断链表是否为空。v 在单链表尾部追加数据元素。v 在单链表的第i个结点的位置前插入一个值为value的结点。v 删除单链表的第i个结点,只是修改引用域,逻辑上的删除,由垃圾回收器回收。v 获得单链表中第i个数据元素。v 在单链表中查

6、找值为value的结点。所有的操作都是基于List中的私有变量head和通过方法得到的长度,利用他们实现节点的查找和定位。1.2.4 客户的抽象客户用类进行抽象建模,在客户类Consumer中定义相关字段(信息)、属性(字段的操作方式)、构造方法(客户创建方式)和实例方法(操作函数)。所要定义的属性、字段和方法参见图-1。 图-1 客户类的结构图-1中类要调用消费方法时,消费方法又调用计算折扣方法。左边一列没有注释的内容为类中各字段对应的属性,用于对外写入和读入字段的值。右边带有注释的内容为属于类的字段,是对客户信息的抽象。二、需求分析2.1 客户(管理对象)需求2.1.1 客户的基本信息注册

7、登记时,每个客户都有唯一的ID,在方便管理的基础上,管理员可对客户的基本个人信息,如ID,姓名,电话等等,进行增加、删除、修改和查找,但是无法直接修改客户的累计消费、享有优惠、积分,这三个信息是执行消费操作时由系统后台自动更改的。2.1.2 积分设置当用户每消费一次,都由管理员用系统执行添加消费操作,操作成功就有一笔积分与以前的积分进行累加,记录在系统中,并按照相关的积分政策,可享受打折优惠等,或累计一定的积分,可为会员类型进行升级。2.1.3 消费设置在系统中,每次消费操作得到管理员输入的有效消费金额,调用折扣计算函数访问客户的享有优惠信息,计算出实际支付款,显示次实付款以及此次消费享有的优

8、惠,购买成功后显示最新积分。2.2 数据需求应使用string对每个客户的基本信息进行存储。用户消费、积分用double类型存储。然后运用链表的存储结构将用户所有信息进行保存。继而完成各种功能。2.3题目的功能v 采用一定的存储结构进行客户信息的存储;v 对客户的信息可以进行修改、删除、添加;v 能够根据消费情况进行客户积分的累加;v 根据积分情况,对客户实行不同程度的打折优惠;2.4系统各项功能描述2.4.1根据不同的积分区间对客户进行打折具体如下:积分满500享受1元优惠,积分满1000享受2元优惠,积分满2000享受5元优惠,积分满5000享受9折优惠,积分满10000享受VIP的7折优

9、惠。 2.4.1用例分析v 用例1v 用例名:录入客户及商品信息行为者:超市管理员v 目的:完成对客户及商品信息的录入管理v 过程描述:v 录入客户(商品)的详细信息包括客户的姓名、身份证号、及现有的积分(商品名、商品的序列号、商品的价格、商品的数量)通过客户文件in.txt(in2.txt)文件或者键盘输入读取客户(商品)信息对键盘输入的客户的积分初始化为0;输入客户(商品)名称能查找到相应信息;根据客户的积分信息及打折信息给客户实现打折优惠;v 异常处理:无。v 用例2v 用例名:客户信息管理。行为者:超市管理员。v 目的:完成对客户信息的管理。v 过程描述:v 超市管理员输入客户的姓名和

10、ID号。对客户进行相应的增、删、查、改的操作并能正确的显示客户信息对客户进行报表统计;保存客户信息录入客户信息文件out.txtv 异常处理:无。v 用例3v 用例名:客户消费管理。行为者:超市管理员。v 目的:完成对客户购买消费的计算并根据客户消费返回客户积分;v 过程描述:v 超市管理员输入客户的身份证号查找到相应的客户并显示客户的积分及打折信息,如果客户不存在则打印此用户不存在;输入客户购买的商品序号打印出商品的信息。输入客户购买的商品数量并累加到consumer的消费中;退出系统;v 异常处理:无。三、技术方案3.1软硬件环境3.1.1 系统软件:本课程设计的系统开发平台为Window

11、sXP及以上。程序设计语言为C#语言,程序运行平台可Windws98/2000/XP/Seven。需要Visual Studio 2013编程软件和.Net Framework组件。3.1.2系统硬件的需求:Pentium4800MHZ或者更高主频CPU512MB以上内存。3.2配置方案Windows7操作系统,VS2013开发工具及平台。3.3 关键技术C#窗体应用技术,c#泛型和面向对象编程,数据结构原理及算法,单链表的基本操作。4、 总体设计4.1 系统功能架构系统的功能架构参见图-2: 图-2 系统功能的结构4.2 各模块功能架构4.2.1添加 图-3 添加客户4.2.2删除 图-4

12、删除客户4.2.3修改 图-5 修改客户4.2.4查找 图-6 查找客户4.2.5添加消费 图-7 添加消费4.2.6 查看所有 图-8 查看所有五、详细设计5.1节点的定义class Node / 定义单链表数据结构 private T data; /数据域 字段 public T Data / 数据域 属性 get return data; set data = value; private Node next; /指针域 字段 public Node Next /指针域 属性 get return next; set next = value; /构造函数 public Node() /

13、空节点 this.data = default(T); this.next = null; public Node(T data, Node next) /数据域,指针域 节点 this.data = data; this.next = next; public Node(T data) /数据域 节点 next = null; this.data = data; public Node(Node next) /指针域 节点 this.next = next; 5.2单链表的实现以及基本操作接口5.2.1单链表的字段、构造方法: class List : IListDS private Node head; / 单链表头结点 字段

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > 解决方案

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号