詳解C語言之實現通訊錄
基本思路和代碼實現
為了代碼清晰易讀,我們創(chuàng)建一個Main.c源文件用來實現代碼的基本邏輯。創(chuàng)建一個Contact.h源文件用于封裝實現功能的函數,創(chuàng)建Contact.h頭文件用于函數的聲明。
首先就是構架代碼基本框架,在主函數中實現打印菜單和循環(huán)的功能 (這里為了好截圖switch里的語句縮進得比較緊湊)
基本邏輯實現后開始考慮創(chuàng)建通訊錄,通訊錄里會記錄人的信息。所以要先能夠描述人的信息: 創(chuàng)建表達人的信息的結構體類型,在Contact.h
中定義:
而通訊錄里記錄的是多人的信息,所以創(chuàng)建通訊錄實際上就是創(chuàng)建上述結構體的數組。這里需要思考一個問題,在之后實現函數的功能比如增刪時,怎么才能得知從哪里增加或者在什么范圍內查找并刪除。這就需要用到一個能表達當前通訊錄有多少個人的變量。而這個變量也能夠用來描述通訊錄,與其把他獨立定義在主函數里不如創(chuàng)建一個通訊錄的結構體,將其定義在里面。這樣一來此變量的意義更加明確,也不用每次調用函數時都要額外傳遞他的參數,只需傳結構體就行了。創(chuàng)建通訊錄的結構體類型,在Contact.h
中定義:
創(chuàng)建完了之后接著進行通訊錄初始化,封裝一個初始化函數InitContact,再設計好其他函數名寫在相應位置處:
然后開始具體實現函數的功能。
初始化函數InitContact
:
增加函數AddContact
:
刪除函數DelContact(這里封裝了一個FindName函數,其功能是找到名字相同的結構體數組元素則返回其下標,未找到則返回-1):
查找函數SeachContact
:
修改函數ModifyContact
:
打印函數ShowContact
:
FindName
函數:
SortContact
排列函數可以有多種不同的排列方式,這可以由自己設計。還可用qsort函數加上自己的比較函數來實現更多類型的排列,這里就不實現此函數了。再做好函數聲明引好頭文件,到這里通訊錄的實現就完成了。
其他探討
在設計如名字和電話住址等數組的大小時,可以使用#define定義
當之后需要修改這些數組的大小時,不用再去一個一個找到每個使用這些數組的地方進行修改,直接修改全局變量的值即可,非常方便。
在判斷數字時,可以使用枚舉常量將數字替換成有實際意義的詞
有了枚舉常量,即使代碼過長,也不用在反復翻閱尋找數字所代表的意義,直接從詞語含義上就能得知。增加了代碼的可讀性。
總結
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!