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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

本文(使用java仓库管理系统设计.docx)为本站会员(b****7)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

使用java仓库管理系统设计.docx

1、使用java仓库管理系统设计使用JAVA仓库管理系统毕业设计系统开发必要性及介绍系统概要设计系统详细设计系统源代码调试分析和测试结果系统使用说明书心得体会参考文献课程设计题目:仓库货品信息管理系统一、系统开发必要性及介绍1.必要性仓库管理是现代物流管理一个重要组成部分,仓库货物管理信息系统设计,可以实现对存储货物信息及统计单据计算机管理,简化作业程序,提高作业效率,为企业创造更高利润。2.主要功能介绍本系统有对库存货品信息输入、插入、删除、查找等功能,并能将建立和更新库存信息保存于文件供输出或打印。对于查找、删除等功能要求能按货品名、货品号分别进行。每个货品相关信息包括:货品号、货品名、货品库

2、存量、进货日期、货品生产厂家及供应商等。二、系统概要设计1.系统设计任务要求系统能实现库存货品信息输入、插入、删除、查找等功能,并能将建立和更新库存信息保存于文件供输出或打印。对于查找、删除等功能能够按货品名、货品号分别进行。每个货品相关信息包括:货品号、货品名、货品库存量、进货日期、货品生产厂家及供应商等。2.方案确定库存货品信息管理系统要求实现许多功能,可遵循结构化程序设计思想来进行本系统设计自顶向下,逐步细化,也就是将软件设计任务划分成许多容易解决小子任务,即分解出许多子功能模块进行设计。本程序经过分析可划分出6个子任务:输入、输出、插入、删除、查找和保存。3.模块划分 (1)程序设计模

3、块连接图库存货品信息管理系统模块连接结构如下图:4.环境要求硬件:PC机软件:电脑安装有TC集成环境三、系统详细设计1数据结构设计(1)数据结构选择选取动态数据结构,本系统是通过双向链表来完成。动态存储分配与释放:申请存储空间函数malloc( )函数首部原型为void * malloc(unsigned int size)释放存储空间函数free( )函数首部原型为void free(void*p)动态数据结构双向链表 (2) 数据类型选择struct commodity /*定义双向链表结构体*/int number; /*货物编号*/ char namemax; /*货物名称*/ int

4、 counter; /*货物数量*/ struct commodity *piror, *next; /*定义两指针,分别指向其前驱和后继*/;(3)变量函数说明:COM *input( )操作结果:输入货品信息COM *insert_perf( )操作结果:插入某货品COM *del_perf( )操作结果:删除某货品serch( )操作结果:查找某货品print_perf( )操作结果:输出某货品save(COM*head)操作结果:保存COM *openfile( )操作结果:载入2.流程框图查找模块和载入模块算法框图在此略。(1)输入模块 NY N Y N Y Y(2)插入模块 N Y

5、 N Y (3)保存模块 N Y N Y (4)输出模块 YY N Y N对以上各模块文字解释说明:(1)输入模块:其实就是一个建立链表操作模块。建立链表具体操作就是逐一输入各结点数据,并建立其前后相链关系。首先设三个指针变量:head,ptr1,ptr2。它们都是指向结构体类型数据。先使head值为NULL,这是链表为空情况。用malloc函数开辟一个结点,并使ptr1,ptr2都指向它,之后从键盘读入一个货品数据给ptr1所指向结点。当输入ptr1-num不为0时,令headptr1;ptr2=ptr1,即把ptr1值赋给head,使ptr2,ptr1,head都指向这一新开辟结点,此结点

6、就成为链表中第一个结点。再开辟一个新结点并使ptr1指向它,读入该结点数据,如果输入ptr1-num不为0,则应链入这第二个结点,这时和上一个结点处理不同,是将ptr1值赋给ptr2-next,也就是使第一个结点next成员指向第二个结点,接着将ptr2也指向结点2。再开辟一个新结点并使ptr1指向它,读入该结点数据,同样将ptr1值赋给ptr2-next,也就是使第三个结点链接到第二个结点之后,并接着将ptr1值赋给ptr2,使ptr2指向结点3。再开辟一个新结点,并使ptr1指向它,输入该结点数据,如果输入ptr1-num为0,则是输入结束标志,此结点不被链接到链表中,就将NULL赋给pt

7、r2-next。建立链表过程至此结束,ptr1最后所指结点并未链入链表中。(2)插入模块:要完成是链表插入操作,即将一个新结点插入到一个已有链表中,对刚刚建立链表,首先新设一个指针变量ptr0,并开辟一个结点使ptr3指向它,输入该结点数据,即新货有关数据,接下来查找要插入位置结点,找到后只需修改此结点和ptr0指向结点指针域值即可,链表中所有元素位置均不需移动,这就体现了链表优点。(3)删除模块:要完成是链表删除操作,只需修改链表中要删除结点前一个结点链指针。使之指向被删除结点后面一个结点即可。(4)保存模块:将最终想要保留数据信息保存于文件中。(5)输出模块:要完成是依次输出链表中各结点数

8、据操作。首先找到链表头结点地址,也就是head值,然后设一个指针变量ptr1,先指向第一个结点,输出ptr1所指结点,然后使ptr1后移一个结点,再输入直至链表尾结点结束。四、系统源代码#include /*标准输入/输出头文件*/#include /*包含绘制图形函数等头文件*/#include /*包含字符串处理函数头文件*/#include /*包含动态存储与释放函数头文件*/#include#define LEN sizeof(COM)#define PRINT % -15ld% -15s% -15dn,ptr1-num,ptr1-name,ptr1-count#define CHEC

9、K_COUNT ptr1-countcountnum);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,&p

10、tr1-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 p

11、rintf(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(C

12、HECK_COUNT) printf(Please input the right goodscount!n); while(CHECK_COUNT); ptr2-next=NULL; gotoxy(1,24); printf(Finish the inputting of goodsmessage,press any key to back to last Menu,please save:); getch(); return(head);/*插入模块*/COM * insert( ) COM * ptr3; char string1 =goodsnumber; char string2 =

13、goodsname; char string3 =goodscount; char judge10; clrscr( ); gotoxy(18,10); printf(Please input inserted goodsfliename:); head=openfile( ); if(head=NULL) return(NULL); else do clrscr( ); printf(Please input inserted goodsgoodsmessage:n); if(ptr3=(COM*)malloc(LEN)=NULL) printf(No enough memory,fail

14、to creat node!); getch(); do printf(Please input goods%s(0):n,string1);scanf(%ld,&ptr3-num); flushall( ); if(ptr3-numname);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); pt

15、r1=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(P

16、ress any key to back to last Menun); gotoxy(16,12); printf(And make sure to Save(6) them or you will lose them!n); getch( ); return(head);/*删除模块*/COM *delet( ) char name10; char judge10; int sel; int del_num; clrscr( ); gotoxy(20,10); printf(Please input delected goodsfliename:); head=openfile( ); c

17、lrscr( ); if(head=NULL) return(NULL); else do do clrscr( ); gotoxy(3,4); printf(Please input delected goodsmessage:); gotoxy(1,9); printf( *1.Del depend on goodsnumbern); gotoxy(1,10); printf( *2.Del depend on goodsnamen); gotoxy(10,22); printf(please choose a number between 1 and 2:); scanf(%d,&sel

18、); 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(S

19、uccess 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 goodsmes

20、sage!nn); else printf(nCant find this goodsmessage!nn); 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 Menun); gotoxy(16,12); printf(And make sure to Save(6)

21、 them or you will lose them!n); getch( ); return(head); /*查找模块*/void search( )char name10; char judge10; int sel; long int sel_num; clrscr( ); gotoxy(18,10); printf(Please press searched goodsfliename:); head=openfile( ); if(head=NULL) return; else do do clrscr( ); gotoxy(5,4); printf(Please choose

22、the way to search:); gotoxy(1,9); printf( *1.Search depend on goodsnumbern); printf( *1.Search depend on goodsnamen); 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:cl

23、rscr( ); 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 go

24、odscountnn); printf(PRINT); else printf(nCant find this goodsmessage!nn); 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(Pl

25、ease input printed goodsfilename:); head=openfile( ); if(head=NULL) return; else clrscr( ); printf( The printed result as follows:n); printf(goodsnumber goodsname goodscountnn); 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 goodscountnn);

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1