《C語言課程設(shè)計 倉庫管理系統(tǒng)》由會員分享,可在線閱讀,更多相關(guān)《C語言課程設(shè)計 倉庫管理系統(tǒng)(22頁珍藏版)》請在裝配圖網(wǎng)上搜索。
1、《C語言程序設(shè)計》實訓(xùn)報告
實訓(xùn)題目: 倉庫管理系統(tǒng)
專業(yè):
班級:
姓名:
成績:
一:需求分析
1:問題
該系統(tǒng)所應(yīng)包含的信息有以下一些:
產(chǎn)品,倉庫。
根據(jù)需求,該系統(tǒng)所應(yīng)實現(xiàn)的功能有以下一些:
輸入密碼進入操作界面
產(chǎn)品入庫,產(chǎn)品出庫。
查詢指定倉庫編號的入庫記錄
查詢指定產(chǎn)品編號的入庫記錄
查詢指定入
2、庫時間的入庫記錄
查詢指定倉庫編號的出庫記錄
查詢指定產(chǎn)品編號的出庫記錄
查詢指定出庫時間的出庫記錄
查詢倉庫中的產(chǎn)品是否過期
可以在操作過程中修改密碼
2、系統(tǒng)
采用C語言實現(xiàn),開發(fā)環(huán)境為VC,可以運行在操作系統(tǒng)windows98及以上皆可。
3.運行要求
1)可以進行隨便操作,不受限制。
2)界面友好,操作方便,例如在進行產(chǎn)品出入庫和查詢時有提示操作。
二、總體設(shè)計
1、系統(tǒng)流程設(shè)計
根據(jù)系統(tǒng)要求,設(shè)計如下的系統(tǒng)流程
2.系統(tǒng)模塊設(shè)計如下,有三大基本功能:
1.出庫
2.入庫
3.查詢
倉庫管理
產(chǎn)品入庫
3、產(chǎn)品出庫
查詢指定倉庫入庫記錄
查詢指定倉庫出庫記錄
查詢指定產(chǎn)品入庫記錄
查詢指定產(chǎn)品出庫記錄
判斷倉庫和產(chǎn)品編號是否存在
判斷入庫日期是否合法
判斷入庫數(shù)量是否大于零
判斷字符長度
判斷閏年與非閏年
判斷每月天數(shù)是否合法
判斷倉庫和產(chǎn)品編號是否存在
判斷出庫日期是否合法
判斷入庫數(shù)量是否大于零
判斷出庫數(shù)量是否大于零
判斷是否小于當前庫存量
判斷字符長度
判斷閏年與非閏年
判斷每月天數(shù)是否合法
查詢指定年月日的出入庫查詢
修改密碼
輸入密碼
三:總體思路
菜單顯示:實現(xiàn)操作某功能時有相應(yīng)的提示。
功能選擇:每一種功能用相應(yīng)的操作數(shù)
4、字相對應(yīng)。
產(chǎn)品出入庫:在原有鏈表的基礎(chǔ)上進行插入操作。
查詢記錄:調(diào)用對應(yīng)的查詢函數(shù)來實現(xiàn)。
四:詳細設(shè)計
1:定義結(jié)構(gòu)體變量
日期:struct warehouse{
int wnum;
char wname[20];
char changename[20];
}wh[5];
產(chǎn)品:
struct product{
int pnum;
char pname[20];
char norms[10];
}pr[10];
鏈表:
struct manage{
int wnum;
int pnum;
char data[15];
int
5、 number;
int operate;
struct manage *next;
};
為了能實現(xiàn)不受限制的產(chǎn)品出入庫,采用鏈表的結(jié)構(gòu)保存產(chǎn)品的信息,在增加產(chǎn)品出入庫時,創(chuàng)建一個新的節(jié)點,將其插入到鏈表中,示意圖如下。
Wnum,pnum,data[15], Number,operate next
Wnum,pnum,
Number,operate next
Wnum,pnum, NULL
Number,operate
2:模塊化設(shè)計
進入設(shè)計:
以輸入密碼的方式進入,最多可輸入三次,如果第三次輸入錯誤,系統(tǒng)將自動退出。
6、這樣保證了倉庫管理這一程序操作的保密性,保證了倉庫管理的安全性。
下一次輸入正確的密碼進入,先顯示出倉庫的信息,如下圖:
閃動經(jīng)大約5-8秒后進入主界面。
主界面實現(xiàn):void screen();/*菜單界面函數(shù)*/
模塊功能:來清晰的實現(xiàn)人機對話完成不同功能的選擇。每完成相應(yīng)操作都會清空界面。
用戶輸入菜單項前面的數(shù)字,主菜單消失,進入該模塊的相應(yīng)界面,進行相應(yīng)的操作,完成后,回到主界面。
產(chǎn)品入庫:struct manage *Instore(struct manage *); /*插入入庫鏈表函數(shù)*/調(diào)用此函數(shù)整體實現(xiàn)產(chǎn)品入
7、庫。
1、 日期格式合法性:int date(char data[]); /*日期格式是否合法函數(shù)*/
模塊功能:判斷長度是否為十,第五位和第八位是否為‘-’,通過atoi()分離日期字符串保存到日期結(jié)構(gòu)體中調(diào)用閏年函數(shù)、月份和月份天數(shù)的合法性函數(shù)。各函數(shù)返回1或0來判斷成立與否。
2、 閏年判斷:int Isleapyear(int ); /*判斷是否為閏年函數(shù)*/是閏年返回1,否返回0.
3、 月份和天數(shù)合法判斷:int numday(struc
8、t data ); /*判斷輸入天數(shù)是否合法函數(shù)*/
模塊功能:定義一個月份數(shù)組t[13]={0,31,28,31,30,31,30,31,31,30,31,30,31}、調(diào)用閏年函數(shù)判斷年份當為閏年且為二月時注意t[2]要加1.月份要小于12,月份結(jié)構(gòu)體中天數(shù)要小于每月天數(shù)。成立返回1,不成立返回0.
4、 產(chǎn)品編號和倉庫編號、入庫數(shù)量判斷:int number(struct manage *); /*判斷倉庫和產(chǎn)品號存在和入庫數(shù)量函數(shù)*/
模塊功能:循環(huán)查詢倉庫數(shù)組和產(chǎn)品數(shù)組來判讀編號是否存在。
產(chǎn)品出庫:struct
9、manage *Outstore(struct manage *); /*插入出庫鏈表函數(shù)*/ 大致和入庫一樣,但要多調(diào)用判斷庫存量函數(shù)。
1:查詢庫存量函數(shù):int Search(struct manage *,struct manage *);
模塊功能:當鏈表不為空,逐個比較結(jié)點存在入庫記錄則得到入庫數(shù)量,存在出庫記錄得到出庫數(shù)量,兩者差比較如果大于0返回1,反之返回0.
查詢倉庫記錄:void searchwarehouse(struct manage *,int); /*查詢記錄函數(shù)*/
模塊功能:輸入
10、你要查詢的倉庫編號和操作類型調(diào)用鏈表來實現(xiàn)查詢。存在調(diào)用打印函數(shù)。
查詢你產(chǎn)品記錄:void searchproduct(struct manage *,int);/*查詢產(chǎn)品記錄*/
模塊功能:輸入你要查詢的產(chǎn)品編號和操作類型調(diào)用鏈表來實現(xiàn)查詢。存在調(diào)用打印函數(shù)。
打印記錄:void print(struct manage *); /*輸出記錄函數(shù)*/
模塊功能:輸出記錄。
四:測試結(jié)果
1:產(chǎn)品入庫
輸入10001 11001 12 12,測試結(jié)果
原因:輸入日期長度不滿足1
11、0.
輸入10001 11001 2004-02-30 1,測試結(jié)果
原因:閏年二月份天數(shù)超過了29.
輸入10001 11001 2000-13-12 12,測試結(jié)果
原因:月份超過了12。
輸入1 11001 2000-11-11 12,測試結(jié)果
原因:倉庫編號錯誤。
輸入10001 11001 2000-12-12 12,測試結(jié)果
入庫成功。
2:產(chǎn)品出庫
輸入 10002 11001 2001-12-12 12,測試結(jié)果
原因:10002倉庫中沒有此產(chǎn)品。
輸入10001 11001 2007-12-12 50,測試結(jié)果
12、
原因:庫存量小于50
輸入10001 11001 2001-12-12 11,測試結(jié)果
出庫成功。
3.查詢倉庫的入庫記錄
輸入倉庫編號 10005,測試結(jié)果
原因:倉庫沒有入庫記錄。
輸入倉庫編號10001,測試結(jié)果
結(jié)果如上。
4:查詢倉庫的出庫記錄
輸入10002,測試結(jié)果
輸入10003,測試結(jié)果如下:
原因:沒有庫存量
輸入10001,測試結(jié)果
打印多條記錄。
5:查詢產(chǎn)品入庫記錄
輸入11001,測試結(jié)果
輸入11003,測試結(jié)果
原因:不存在產(chǎn)品入庫記錄。
6:查詢產(chǎn)品出庫記錄
輸入10001
13、,測試結(jié)果
7:查詢指定日期的出庫和入庫記錄
輸入2000-12-12
輸入2005-01-01
原因:該時間沒有入庫和出庫記錄。
8.修改密碼
修改密碼操作采用網(wǎng)上大多數(shù)網(wǎng)站的密碼修改模式。即先輸入原密碼,再輸入要修改的密碼兩次,第一次輸后,第二次輸入的要和第一次相同,以便確認其正確性。修改時輸入原密碼共有三次機會,以保證安全性,如果三次輸入全錯,系統(tǒng)自動退出,操作如下:
正確修改密碼如下;
9:查詢產(chǎn)品是否過期
輸入年份為2001,月份為01,天數(shù)為02,其結(jié)果如下:
10.按0退出程序,這一步并不是簡單的退出了程序,而是在退出之前,進行了內(nèi)存
14、空間的釋放。其代碼如下:
void freerecord(struct manage *head)
{
struct manage *p=head;
while(head) /*釋放內(nèi)存*/
{
head=head->next;
free(p);
p=head;
}
}
五:實訓(xùn)總結(jié)
實訓(xùn)感想:通過實訓(xùn)我感覺到自己動手編程能力的提高,把自己課堂上學到的知識應(yīng)用于實踐中,在編程過程中經(jīng)常遇到問題,但在老師耐心指導(dǎo)下一個一個的解決了,每次的練習都增長了新知識當我一個程序運行處結(jié)果時我激動不已,這也逐漸培養(yǎng)了我對學習C語言的
15、興趣,尤其是這次綜合練習更是讓我看到精通C語言還有很多路要走,雖然實訓(xùn)即將結(jié)束但我學習C語言的腳步不會停止,我還會繼續(xù)上機培養(yǎng)我的編程能力。借助這門語言我會努力學好軟件工程中其他學科,我要在編程這條道路上一直走下去。
設(shè)計亮點:1界面友好,較好實現(xiàn)了人-機對話。
2使用結(jié)構(gòu)化程序設(shè)計思路,步驟清晰通過不同函數(shù)來實現(xiàn)不同模塊功能。
3每操作一步就清理界面,讓人看起來清楚明了。
4程序清楚,分行恰當,注釋合理。
5 操作不受限制,可以隨時出入庫和進行查詢。
不足: 有些細節(jié)沒有考慮清楚,程序還不夠優(yōu)化。