C語言實現簡單通訊錄功能
本文實例為大傢分享瞭C語言實現簡單通訊錄功能的具體代碼,供大傢參考,具體內容如下
1.存放聯系人信息
2.信息:名字+年齡+性別+電話+住址
3.增加聯系人
4.刪除聯系人
5.查找聯系人
6.修改聯系人
7.排序
test.c源文件代碼如下:
#define _CRT_SECURE_NO_WARNINGS 1 #include "contact.h" void menu() { printf("#####################################\n"); printf("##### 1. add 2. del #####\n"); printf("##### 3. search 4. modify #####\n"); printf("##### 5. show 6. sort #####\n"); printf("##### 0. exit #####\n"); printf("#####################################\n"); } //創建一個枚舉類型,分別對應菜單選項 enum Option { EXIT, ADD, DEL, SEARCH, MODIFY, SHOW, SORT, }; int main() { int input = 0; //創建一個通訊錄 struct Contact con; //初始化通訊錄 InitContact(&con); //最多可以放3個聯系人信息 //空間不夠再增容 do { menu();//進入循環,先打印菜單 printf("請選擇:>"); scanf("%d", &input);//用戶選擇操作 switch (input) { case ADD: AddContact(&con); break; case DEL: DelContact(&con); break; case SEARCH: SearchContact(&con); break; case MODIFY: ModifyContact(&con); break; case SHOW: ShowContact(&con); break; case SORT: SortContact(&con); break; case EXIT: SaveContact(&con); //銷毀通訊錄 DestroyContact(&con); printf("退出\n"); break; default: printf("選擇錯誤\n"); break; } } while (input); return 0; }
contact.c源文件代碼如下:
#define _CRT_SECURE_NO_WARNINGS 1 #include "contact.h" //檢測通訊錄容量 void CheckCapacity(struct Contact* pc) { //斷言 assert(pc); if (pc->sz == pc->capacity)//如果有效聯系人等於最大容納量 { //增加容量 struct PeoInfo* ptr = realloc(pc->data, (pc->capacity + 2) * sizeof(struct PeoInfo)); if (ptr != NULL)//如果不為空,表示增容成功 { pc->data = ptr; pc->capacity += 2; printf("增容成功\n"); } else { perror("AddContact::realloc"); return; } } } //加載有效聯系人信息 void LoadContact(struct Contact* pc) { assert(pc); struct PeoInfo tmp = { 0 };//臨時空間 FILE* pfRead = fopen("contact.txt", "rb");//打開文件,讀取數據 if (NULL == pfRead) { perror("open file for reading"); return; } //加載數據 //每次讀取一個聯系人信息,直到frea返回值小於1,表示讀取完畢,循環結束 while (fread(&tmp, sizeof(struct PeoInfo), 1, pfRead)) { CheckCapacity(pc); pc->data[pc->sz] = tmp; pc->sz++; } //關閉文件 fclose(pfRead); pfRead = NULL;//置空,防止變成野指針 } //初始化通訊錄 void InitContact(struct Contact* pc) { assert(pc); pc->sz = 0; pc->capacity = DEFAULT; pc->data = (struct PeoInfo*)malloc(DEFAULT * sizeof(struct PeoInfo));//動態申請空間 if (pc->data == NULL) { perror("InitContact::malloc"); return; } LoadContact(pc);//加載通訊錄的信息 } //增加聯系人 void AddContact(struct Contact* pc) { assert(pc); CheckCapacity(pc);//檢查容量是否為滿,是則進行增容 //輸入增加指定聯系人的信息 printf("請輸入名字:>"); scanf("%s", pc->data[pc->sz].name); printf("請輸入年齡:>"); scanf("%d", &(pc->data[pc->sz].age)); printf("請輸入性別:>"); scanf("%s", pc->data[pc->sz].sex); printf("請輸入電話:>"); scanf("%s", pc->data[pc->sz].tele); printf("請輸入地址:>"); scanf("%s", pc->data[pc->sz].addr); printf("添加成功\n"); pc->sz++;//有效聯系人加1 } //銷毀通訊錄 void DestroyContact(struct Contact* pc) { assert(pc); free(pc->data);//釋放申請的動態內存空間 pc->data = NULL;//置為空指針 pc->capacity = 0;//容量置0 pc->sz = 0;//有效聯系人置0 } //顯示通訊錄信息 void ShowContact(const struct Contact* pc) { assert(pc); int i = 0; printf("%20s\t%5s\t%10s\t%12s\t%50s\n\n", "name", "age", "sex", "tele", "addr"); for (i = 0; i < pc->sz; i++) { //打印每一個數據 printf("%20s\t%5d\t%10s\t%12s\t%50s\n", pc->data[i].name, pc->data[i].age, pc->data[i].sex, pc->data[i].tele, pc->data[i].addr); } } //查找指定聯系人 int FindContactByName(const struct Contact* pc, const char* name) { assert(pc && name); int i = 0; for (i = 0; i < pc->sz; i++) { if (strcmp(pc->data[i].name, name) == 0) { return i; } } //找不到 return -1; } //刪除指定聯系人 void DelContact(struct Contact* pc) { assert(pc); if (pc->sz == 0) { printf("通訊錄為空,無法刪除\n"); return; } char name[NAME_MAX] = { 0 }; printf("請輸入要刪除聯系人的名字:>"); scanf("%s", name); //查找到刪除的人 int pos = FindContactByName(pc, name); if (pos == -1) printf("指定聯系人不存在\n"); else { //刪除 int i = 0; for (i = pos; i < pc->sz-1; i++) { pc->data[i] = pc->data[i + 1]; } pc->sz--; printf("成功刪除\n"); } } //查找指定聯系人 void SearchContact(const struct Contact* pc) { assert(pc); char name[NAME_MAX] = { 0 }; if (pc->sz == 0) { printf("通訊錄為空,無法查找\n"); return; } printf("請輸入要查找的聯系人名字:>"); scanf("%s", name); int pos = FindContactByName(pc, name); if (-1 == pos) printf("查無此人\n"); else { printf("%15s\t%5s\t%8s\t%15s\t%30s\n\n", "name", "age", "sex", "tele", "addr"); printf("%15s\t%5d\t%8s\t%15s\t%30s\n", pc->data[pos].name, pc->data[pos].age, pc->data[pos].sex, pc->data[pos].tele, pc->data[pos].addr); } } //修改指定聯系人 void ModifyContact(struct Contact* pc) { assert(pc); char name[NAME_MAX] = { 0 }; if (pc->sz == 0) { printf("通訊錄為空,無法修改\n"); return; } printf("請輸入要修改的聯系人名字:>"); scanf("%s", name); int pos = FindContactByName(pc, name); if (-1 == pos) printf("要修改的人不存在\n"); else { printf("請輸入新的名字:>"); scanf("%s", pc->data[pos].name); printf("請輸入新的年齡:>"); scanf("%d", &(pc->data[pos].age)); printf("請輸入新的性別:>"); scanf("%s", pc->data[pos].sex); printf("請輸入新的電話:>"); scanf("%s", pc->data[pos].tele); printf("請輸入新的地址:>"); scanf("%s", pc->data[pos].addr); } } //按照名字排序->升序 int cmp_by_name(const void* e1, const void* e2) { return strcmp((((struct PeoInfo*)e1)->name), (((struct PeoInfo*)e2)->name)); } //按照年齡排序->升序 int cmp_by_age(const void* e1, const void* e2) { return ((struct PeoInfo*)e1)->age - ((struct PeoInfo*)e2)->age; } //排序通訊錄 void SortContact(struct Contact* pc) { assert(pc); int input = 0; if (pc->sz == 0) { printf("通訊錄為空,無法排序\n"); return; } printf("按名字排序請輸入1,年齡排序請輸入2:>"); scanf("%d", &input); if (1 == input) { //名字排序 qsort(pc->data, pc->sz, sizeof(struct PeoInfo), cmp_by_name); } else { //年齡排序 qsort(pc->data, pc->sz, sizeof(struct PeoInfo), cmp_by_age); } } //保存通訊錄 void SaveContact(struct Contact* pc) { assert(pc); int i = 0; FILE* pfWrite = fopen("contact.txt", "wb");把當前程序的有效聯系人寫入文件 if (NULL == pfWrite)//判斷是否為空指針 { perror("open file for writting"); return; } //寫數據 for (i = 0; i < pc->sz; i++) { fwrite(pc->data+i, sizeof(struct PeoInfo), 1, pfWrite);//進行寫入 } fclose(pfWrite);//關閉文件 pfWrite = NULL;//置為空指針 }
contact.h頭文件代碼如下:
#pragma once #include <string.h> #include <stdio.h> #include <stdlib.h> #include <assert.h> #define DEFAULT 3 #define NAME_MAX 20 #define SEX_MAX 10 #define TELE_MAX 12 #define ADDR_MAX 50 #define MAX 1000 //描述聯系人的信息 struct PeoInfo { char name[NAME_MAX]; int age; char sex[SEX_MAX]; char tele[TELE_MAX]; char addr[ADDR_MAX]; }; //通訊錄-動態增長版本 struct Contact { struct PeoInfo* data; int sz;//通訊錄中當前有效元素個數 int capacity;//通訊錄的當前最大容量 }; //增容 void CheckCapacity(struct Contact* pc); //初始化通訊錄 void InitContact(struct Contact* pc); //銷毀通訊錄 void DestroyContact(struct Contact* pc); //增加聯系人 void AddContact(struct Contact* pc); //顯示通訊錄 void ShowContact(const struct Contact* pc); //刪除指定聯系人 void DelContact(struct Contact* pc); //查找指定聯系人 void SearchContact(const struct Contact* pc); //修改指定聯系人 void ModifyContact(struct Contact* pc); //排序通訊錄 void SortContact(struct Contact* pc); //保存通訊錄到文件 void SaveContact(struct Contact* pc); //加載通訊錄 void LoadContact(struct Contact* pc);
程序運行:
重新運行程序並顯示
之前添加的聯系人會存放在指定文件中,再次運行程序會加載進去,增容成功是因為默認容納的聯系人有3位,要加載4位聯系人,所以自動進行增容。
以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。