JAVA仓库管理系统.doc
《JAVA仓库管理系统.doc》由会员分享,可在线阅读,更多相关《JAVA仓库管理系统.doc(53页珍藏版)》请在咨信网上搜索。
JAVA仓库管理系统 53 2020年5月29日 文档仅供参考 目录 系统开发的必要性及介绍……………………… 系统概要设计…………………………………… 系统详细设计…………………………………… 系统源代码……………………………………… 调试分析和测试结果…………………………… 系统使用说明书………………………………… 心得体会………………………………………… 参考文献………………………………………… 课程设计题目:仓库货品信息管理系统 一、系统开发的必要性及介绍 1.必要性 仓库管理是现代物流管理的一个重要组成部分,仓库货物管理信息系统的设计,能够实现对存储货物信息及统计单据的计算机管理,简化作业程序,提高作业效率,为企业创造更高的利润。 2.主要功能介绍 本系统有对库存货品信息的输入、插入、删除、查找等功能,并能将建立和更新的库存信息保存于文件供输出或打印。对于查找、删除等功能要求能按货品名、货品号分别进行。每个货品的相关信息包括:货品号、货品名、货品库存量、进货日期、货品生产厂家及供应商等。 二、系统概要设计 1.系统设计任务 要求系统能实现库存货品信息的输入、插入、删除、查找等功能,并能将建立和更新的库存信息保存于文件供输出或打印。对于查找、删除等功能能够按货品名、货品号分别进行。每个货品的相关信息包括:货品号、货品名、货品库存量、进货日期、货品生产厂家及供应商等。 2.方案确定 库存货品信息管理系统要求实现许多功能,可遵循结构化程序设计思想来进行本系统的设计——自顶向下,逐步细化,也就是将软件设计任务划分成许多容易解决的小的子任务,即分解出许多子功能模块进行设计。本程序经过分析可划分出6个子任务:输入、输出、插入、删除、查找和保存。 3.模块划分 (1)程序设计模块连接图 库存货品信息管理系统的模块连接结构如下图: 仓库货品信息管理系统 主程序模块 载入模块 保存模块 查找模块 删除模块 插入模块 输出模块 输入模块 4.环境要求 硬件:PC机 软件:电脑安装有TC集成环境 三、系统详细设计 1.数据结构设计 (1)数据结构的选择 选取动态数据结构,本系统是经过双向链表来完成的。 动态存储分配与释放: 申请存储空间函数malloc( ) 函数首部原型为 void * malloc(unsigned int size) 释放存储空间函数free( ) 函数首部原型为 void free(void*p) 动态数据结构——双向链表 (2) 数据类型的选择 struct commodity /*定义双向链表结构体*/ {int number; /*货物编号*/ char name[max]; /*货物名称*/ int counter; /*货物数量*/ struct commodity *piror, *next; /*定义两指针,分别指向其前驱和后继*/ }; (3)变量函数说明: COM *input( ) 操作结果:输入货品信息 COM *insert_perf( ) 操作结果:插入某货品 COM *del_perf( ) 操作结果:删除某货品 serch( ) 操作结果:查找某货品 print_perf( ) 操作结果:输出某货品 save(COM*head) 操作结果:保存 COM *openfile( ) 操作结果:载入 2.流程框图 查找模块和载入模块的算法框图在此略。 开始 (1)输入模块 申请一个结点空间,使ptr1指向它 将ptr1指向结点输入货品的信息 ptr1->num!=0 N NULL=>ptr1 Y ptr1!=NULL N 是否为第一个数据(n=0) Y N Ptr1=>ptr2->next; ptr2=>ptr1->prior Y ptr1=>head Y n+1=>n, ptr1=>ptr2 NULL=>ptr2->next 返回head 结束 (2)插入模块 开始 调入载入模块 Head=NULL 申请一个结点空间,使ptr3指向它 给ptr3指向结点输入预插入货品的信息 Head=>ptr1 ptr1!=NULL N Y 返回NULL ptr1=>ptr2;ptr1->next=>ptr1 ptr2=>ptr1->prior ptr3=>ptr2->next;ptr2=>ptr3->prior NULL=>ptr3->next ”yes”or ”no” N Y 返回head 结束 开始 (3)保存模块 输入预保存文件的文件名 创立文件成功 N Y Head=>ptr1 Ptr1!=NULL N Y 将ptr1指向结点的数据写入文件 Ptr1->next=>ptr1 结束 开始 2030 (4)输出模块 调用载入模块 Head= =NULL Y Y Head=>ptr1 输出ptr1指向结点的货品信息 Ptr1->next=>ptr1 N Ptr1!=NULL Y N 结束 对以上各模块的文字解释说明: (1)输入模块:其实就是一个建立链表的操作模块。建立链表的具体操作就是逐一输入各结点数据,并建立其前后相链的关系。首先设三个指针变量:head,ptr1,ptr2。它们都是指向结构体类型数据的。先使head的值为NULL,这是链表为空的情况。用malloc函数开辟一个结点,并使ptr1,ptr2都指向它,之后从键盘读入一个货品的数据给ptr1所指向的结点。当输入的ptr1->num不为0时,令head=ptr1;ptr2=ptr1,即把ptr1的值赋给head,使ptr2,ptr1,head都指向这一新开辟的结点,此结点就成为链表中的第一个结点。再开辟一个新结点并使ptr1指向它,读入该结点的数据,如果输入的ptr1->num不为0,则应链入这第二个结点,这时和上一个结点的处理不同,是将ptr1的值赋给ptr2->next,也就是使第一个结点的next成员指向第二个结点,接着将ptr2也指向结点2。再开辟一个新结点并使ptr1指向它,读入该结点的数据,同样将ptr1的值赋给ptr2->next,也就是使第三个结点链接到第二个结点之后,并接着将ptr1的值赋给ptr2,使ptr2指向结点3。再开辟一个新结点,并使ptr1指向它,输入该结点的数据,如果输入ptr1->num为0,则是输入结束标志,此结点不被链接到链表中,就将NULL赋给ptr2->next。建立链表过程至此结束,ptr1最后所指结点并未链入链表中。 (2)插入模块:要完成的是链表的插入操作,即将一个新结点插入到一个已有的链表中,对刚刚建立的链表,首先新设一个指针变量ptr0,并开辟一个结点使ptr3指向它,输入该结点的数据,即新货的有关数据,接下来查找要插入位置结点,找到后只需修改此结点和ptr0指向结点指针域的值即可,链表中所有元素位置均不需移动,这就体现了链表的优点。 (3)删除模块:要完成的是链表的删除操作,只需修改链表中要删除结点的前一个结点的链指针。使之指向被删除结点的后面一个结点即可。 (4)保存模块:将最终想要保留的数据信息保存于文件中。 (5)输出模块:要完成的是依次输出链表中各结点的数据的操作。首先找到链表头结点的地址,也就是head的值,然后设一个指针变量ptr1,先指向第一个结点,输出ptr1所指的结点,然后使ptr1后移一个结点,再输入直至链表的尾结点结束。 四、系统源代码 #include<stdio.h> /*标准输入/输出头文件*/ #include<conio.h> /*包含绘制图形函数等头文件*/ #include<string.h> /*包含字符串处理函数头文件*/ #include<stdlib.h> /*包含动态存储与释放函数头文件*/ #include<graphics.h> #define LEN sizeof(COM) #define PRINT "% -15ld% -15s% -15d\n",ptr1->num,ptr1->name,ptr1->count #define CHECK_COUNT ptr1->count<0 #define CHECK_COUNT2 ptr3->count<0 #define NULL 0 typedef struct com {long int num; char name[10]; int count; struct com *prior, *next; }COM; /*定义结构体*/ COM *input(); /*输入货品信息*/ COM *insert( ); /*插入货品信息*/ COM *delet( ); /*删除货品信息*/ void search( ); /*查找货品信息*/ void save(COM *head); /*保存货品信息*/ COM *openfile( ); /*从文件将货品信息载入链表*/ void print( ); /*输出货品信息*/ FILE *fp; /*定义指向文件的指针变量*/ COM *head=NULL; COM *ptr1=NULL,*ptr2=NULL; char filename1[10]; /*定义字符数组,用来存放文件名*/ char filename2[ ]={".dat"}; /*文件扩展名.dat*/ /*输入模块*/ COM *input( ) {char string1[ ]={"number"}; char string2[ ]={"name"}; char string3[ ]={"count"}; int n=1; if((ptr1=(COM*)malloc(LEN))==NULL) /*申请空间函数*/ {printf("No enough memory,fail to creat linklist!"); getch( ); /*无回显的从键盘读取任意一个字符*/ } clrscr( ); printf("Please input depend on the emply(goodsnumber==0 over):\n"); do {printf("Please input the No.%d goods'%s:\n",n,string1); scanf("%ld",&ptr1->num);flushall(); if(ptr1->num==0) {printf("Please press any key to back to last Menu:"); getch( ); free(ptr1); return(0); } printf("Please input the No.%d goods'%s:\n",n,string2);scanf("%s",&ptr1->name); flushall( ); /*刷新缓冲区函数*/ printf("Please input the No.%d goods'%s:\n",n,string3);scanf("%d",&ptr1->count); flushall( ); if(CHECK_COUNT) printf("Please input the right goodscount!\n"); }while(CHECK_COUNT); while(ptr1->num!=NULL) { if(n==1) head=ptr1; else ptr2->next=ptr1; ptr1->prior=ptr2; n=n+1; ptr2=ptr1; if((ptr1=(COM* )malloc(LEN))==NULL) { printf("No enough memory,fail to creat linklist!"); getch( ); } do {printf("Please input the No.%d goods'%s:\n",n,string1); scanf("%ld",&ptr1->num); flushall( ); if(ptr1->num==0) {ptr1->num=NULL; break;} printf("Please input the No.%d goods'%s:\n",n,string2);scanf("%s",&ptr1->name); flushall( ); printf("Please input the No.%d goods'%s:\n",n,string3);scanf("%d",&ptr1->count); flushall( ); if(CHECK_COUNT) printf("Please input the right goodscount!\n"); }while(CHECK_COUNT); } ptr2->next=NULL; gotoxy(1,24); printf("Finish the inputting of goods'message,press any key to back to last Menu,please save:"); getch(); return(head); } /*插入模块*/ COM * insert( ) {COM * ptr3; char string1[ ]={"goodsnumber"}; char string2[ ]={"goodsname"}; char string3[ ]={"goodscount"}; char judge[10]; clrscr( ); gotoxy(18,10); printf("Please input inserted goods'fliename:"); head=openfile( ); if(head==NULL) return(NULL); else do {clrscr( ); printf("Please input inserted goods'goodsmessage:\n"); if((ptr3=(COM*)malloc(LEN))==NULL) {printf("No enough memory,fail to creat node!"); getch(); } do {printf("Please input goods'%s(>0):\n",string1);scanf("%ld",&ptr3->num); flushall( ); if(ptr3->num<=0) {printf("Error inputting!please choose the inserted goods again\n"); getch( );return; } printf("Please input goods'%s:\n",string2);scanf("%s",&ptr3->name);flushall( ); printf("Please input goods'%s:\n",string3);scanf("%d",&(ptr3->count)); flushall( ); if(CHECK_COUNT2) printf("Please input the right goodscount(>0)!\n"); }while(CHECK_COUNT2); ptr1=head; while(ptr1!=NULL) {ptr2=ptr1; ptr1=ptr1->next; ptr1->prior=ptr2; } ptr2->next=ptr3; ptr3->prior=ptr2; ptr3->next=NULL; printf("\nInserting success!Cotinue to insert?(yes or no):"); scanf("%s",judge); clrscr( ); }while(! strcmp(judge,"yes")); gotoxy(20,10); printf("Inserting success!\n"); gotoxy(18,11); printf("Press any key to back to last Menu\n"); gotoxy(16,12); printf("And make sure to Save(6) them or you will lose them!\n"); getch( ); return(head); } /*删除模块*/ COM *delet( ) {char name[10]; char judge[10]; int sel; int del_num; clrscr( ); gotoxy(20,10); printf("Please input delected goods'fliename:"); head=openfile( ); clrscr( ); if(head==NULL) return(NULL); else do {do {clrscr( ); gotoxy(3,4); printf("Please input delected goods'message:"); gotoxy(1,9); printf(" *1.Del depend on goodsnumber\n"); gotoxy(1,10); printf(" *2.Del depend on goodsname\n"); gotoxy(10,22); printf("please choose a number between 1 and 2:"); scanf("%d",&sel); switch(sel) {case 1:clrscr( ); gotoxy(6,6); printf("Please input goodsnumber:"); scanf("%d",&del_num); break; case 2:clrscr( ); gotoxy(6,6); printf("Please input goodsname:"); scanf("%s",&name); break; } }while(sel!=1&&sel!=2); ptr1=head; if(ptr1->num==del_num||(strcmp(ptr1->name,name)==0)) { head=ptr1->next; printf("Success to delect goodsmessage!\n"); } else /*判断是否是目标结点*/ { while(ptr1!=NULL&&ptr1->num!=del_num&&strcmp(ptr1->name,name)!=0) {ptr2=ptr1; ptr1=ptr1->next; ptr1->prior=ptr2; } if(ptr1->num==del_num||(strcmp(ptr1->name,name)==0)) {ptr2->next=ptr1->next; ptr1->next->prior=ptr1->prior; free(ptr1); printf("\nSuccess to delect goodsmessage!\n\n"); } else printf("\nCan't find this goodsmessage!\n\n"); } printf("Cotinue to delect?(yes or no):"); scanf("%s",judge); }while(!strcmp(judge,"yes")); clrscr( ); gotoxy(20,10); printf("Delecting success!\n"); gotoxy(18,11); printf("Press any key to back to last Menu\n"); gotoxy(16,12); printf("And make sure to Save(6) them or you will lose them!\n"); getch( ); return(head); } /*查找模块*/ void search( ) {char name[10]; char judge[10]; int sel; long int sel_num; clrscr( ); gotoxy(18,10); printf("Please press searched goods'fliename:"); head=openfile( ); if(head==NULL) return; else do {do {clrscr( ); gotoxy(5,4); printf("Please choose the way to search:"); gotoxy(1,9); printf(" *1.Search depend on goodsnumber\n"); printf(" *1.Search depend on goodsname\n"); gotoxy(10,22); printf("please choose a number between 1 and 2:"); scanf("%d",&sel); switch(sel) {case 1:clrscr( ); printf("Please input goodsnumber:"); scanf("%ld",&sel_num); break; case 2:clrscr( ); printf("Please input goodsname:"); scanf("%s",name); break; } }while(sel!=1&&sel!=2); ptr1=head; while(ptr1!=NULL&&ptr1->num!=sel_num&&strcmp(ptr1->name,name)!=0) ptr1=ptr1->next; if ((ptr1->num==sel_num)||(strcmp(ptr1->name,name)==0)) {printf("\n Success to search goodsmessage!\n"); printf("goodsnumber goodsname goodscount\n\n"); printf(PRINT); } else printf("\nCan't find this goodsmessage!\n\n"); printf("Cotinue to search?(yes or no):"); scanf("%s",judge); }while(!strcmp(judge,"yes")); gotoxy(10,24); printf("Please press any key to back to last Menu:"); getch( ); } /*输出模块*/ void print( ) {int i=1; clrscr( ); gotoxy(18,10); printf("Please input printed goods'filename:"); head=openfile( ); if(head==NULL) return; else clrscr( ); printf(" The printed result as follows:\n"); printf("goodsnumber goodsname goodscount\n\n"); ptr1=head; do {printf(PRINT); ptr1=ptr1->next; if(i/10==1) /*超过十行换页*/ {i=0; printf("Press any key to change page:"); getch( ); clrscr( ); gotoxy(0,6); printf("goodsnumber goodsname goodscount\n\n"); } i=i+1; }while(ptr1!=NULL); gotoxy(10,24); printf("Please press any key to back to last Menu:"); getch( ); } /*保存模块*/ void save(COM *head) { clrscr(); gotoxy(8,13); printf("Please input saved goods'filename(limit to letter or number):"); scanf("%s",filename1); if((fp=fopen(strcat(filename1,filename2),"wb"))==NULL) /*以二进制只写方式打开一个流*/ {printf("Fail to creat FILE!"); getch( ); return; } ptr1=ptr2=head; while(ptr1!=NULL) {if(fwrite(ptr1,sizeof(COM),1,fp)!=1) {printf("Fail to print message to FILE!"); getch( ); return; } ptr1=ptr1->next; } fclose(fp); gotoxy(10,24); printf("Saving success!Press any key to back to last Menu:"); getch(); } /*载入模块*/ COM * openfile( ) {int n=1; scanf("%s",filename1); if((fp=fopen(strcat(filename1,filename2),"rb"))==NULL) {gotoxy(15,13); printf("This filename isn't exist,please check if exist.\npress any key back to Menu"); getch( ); return(NULL); } if((ptr1=ptr2=(COM*)malloc(LEN))==NULL) {printf("No enough memory,fail to creat linklist!\nPlease press any key back to Menu\n"); getch( ); return(NULL); } if(fread(ptr1,sizeof(COM),1,fp)!=1) /*从fp指向的流中读取1个字段,每个字段为COM的字符长,并把它们放到ptr1指向的字符数组中,文件的位置指示器随着所读取的字符数而下移*/ {printf("Fail to print message from FILE!\nPlease press any key back to Menu\n"); getch( ); return(NULL); } if(ptr1->next==NULL) head=ptr1; else { do {if(n==1) head=ptr1; else ptr2->next=ptr1; n=n+1; ptr2=ptr1; if((ptr1=(COM*)malloc(LEN))==NULL) {printf("No enough memory,fail to creat linklist!\nPlease press any key to back to Menu\n"); getch( );return(NULL); } if(fread(ptr1,sizeof(COM),1,fp)!=1- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- JAVA 仓库 管理 系统
咨信网温馨提示:
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【天****】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【天****】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【天****】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【天****】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
关于本文