前面我们已经实现了静态通讯录,下面来实现一下动态通讯录,其框架与静态有多不同,但是很多功能在使用的时候是一样的,这里添加联系人的方式是不同的,所以我们这里只说一下框架和不要改动的地方,这里如果有什么不懂的可以先看看静态通讯录的实现(点击链接即可看静态通讯录的实现),下面进入正题。
1. 框架
每件事请都有逻辑性,实现一个东西也少不了其逻辑。
先来了解一下结构:
这里我们我们使用新了结构,所以只用初始化中改变和对增加联系人这个功能和退出程序时释放通讯录空间这三个地方都有所变动,其他功能和静态一样。
2. 具体实现
这里我只说说初始化通讯录和添加联系人以及退出程序销毁通讯录三个操作的实现
2.1 初始化通讯录
首先我们要对个人信息这个结构体进行申请空间操作(使用malloc库函数实现)并把记录个人信息的数量置为0(没有联系人所以要置为0)还要设置一下整体通讯录的容量大小
2.2 添加联系人信息
首先就是要对个人信息数量和通讯录容量进行一个比较,如果相等就对存储个人信息空间进行扩容,这里使用realloc库函数对其扩容,并且还要把通讯录容量变大。
2.3 退出程序时销毁通讯录
把通讯录的空间释放掉(用free库函数进行释放),在把指向该通讯录的地址置为空指针(防止野指针的存在),再把记录个人信息数量置为0以及把通讯录容量置为0。
3. 多文件形式展示源代码
3.1 main.c文件
#define _CRT_SECURE_NO_WARNINGS 1
#include "Dynamic_AdressList.h"
int main()
{
struct Adress_List List;
Init_Adress_List(&List);
int input = 0;
do
{
menu();
printf("请输出操作前的提示数字,可完成此操作:>");
scanf("%d", &input);
switch (input)
{
case 1:
Add_Linkman(&List);
system("cls");
break;
case 2:
Delete_Linkman(&List);
system("cls");
break;
case 3:
Find_Linkman(&List);
system("cls");
break;
case 4:
Modify_Linkman_Information(&List);
system("cls");
break;
case 5:
SortList_By_age(&List);
system("cls");
break;
case 6:
Show_Adress_List(&List);
system("cls");
break;
case 7:
Delete_AllLinkman(&List);
system("cls");
break;
case 0:
Destory_Adress_List(&List);
printf("------------------退出程序!------------------\n");
break;
default:
printf("-------------输入错误!请重新输入:>-------------\n");
Sleep(1000);
system("cls");
break;
}
} while (input);
system("pause");
return 0;
}
Dynamic_AdressList.c文件
#define _CRT_SECURE_NO_WARNINGS 1
#include "Dynamic_AdressList.h"
void Init_Adress_List(struct Adress_List* List)
{
assert(List);
List->data = (struct Person_Information*)malloc(sizeof(struct Person_Information) * MAX_CAPACITY);
if (List->data == NULL)
{
perror("Init_Adress_List()");
return;
}
List->size = 0;
List->capacity = MAX_CAPACITY;
}
void menu()
{
printf("\n");
printf("************************************************\n");
printf("***** 1.AddLinkman 2.DeleteLinkman ******\n");
printf("***** 3.FindLinkman 4.ModifyLinkman ******\n");
printf("***** 5.SortByAge 6.ShowList ******\n");
printf("***** 7.DeleteAll 0.exit ******\n");
printf("************************************************\n");
printf("\n");
}
void Add_Linkman(struct Adress_List* List)
{
assert(List);
int ret = Judge_Capactiy(List);
if (ret == 0)
{
return;
}
else
{
printf("请输入名字:>");
scanf("%s", List->data[List->size].name);
printf("请输入性别:>");
scanf("%s", List->data[List->size].sex);
printf("请输入电话:>");
scanf("%s", List->data[List->size].phone);
printf("请输入年龄:>");
scanf("%d", &List->data[List->size].age);
printf("请输入家庭住址:>");
scanf("%s", List->data[List->size].adress);
List->size++;
printf("添加联系人成功!\n");
Sleep(800);
}
}
void Show_Adress_List(const struct Adress_List* List)
{
printf("\n");
printf("-------------------------------------------------------------------------------\n");
printf("暂时的通讯录的所有信息:>\n");
printf("%-5s\t%-5s\t%-15s\t%-20s\t%-20s\n", "姓名", "性别", "电话", "年龄", "家庭住址");
int i = 0;
for (i = 0; i < List->size; i++)
{
printf("%-5s\t%-5s\t%-15s\t%-20d\t%-20s\n",
List->data[i].name,
List->data[i].sex,
List->data[i].phone,
List->data[i].age,
List->data[i].adress);
}
printf("-------------------------------------------------------------------------------\n");
printf("\n");
printf("请等上5秒,再次操作!\n");
Sleep(5000);
}
void Delete_Linkman(struct Adress_List* List)
{
char name[MAX_NAME];
printf("请输入你想删除的联系人的姓名:>");
scanf("%s", name);
int ret = Find_By_Name(List, name);
if (-1 == ret)
{
printf("该联系人不存在!\n");
Sleep(800);
}
else
{
int i = 0;
for (i = ret; i < List->size; i++)
{
List->data[i] = List->data[i + 1];
}
List->size--;
printf("成功删除该联系人!\n");
Sleep(800);
}
}
void Find_Linkman(struct Adress_List* List)
{
printf("请输入你想查找的联系人的姓名:>");
char name[MAX_NAME];
scanf("%s", name);
int ret = Find_By_Name(List, name);
if (ret == -1)
{
printf("此联系人不存在!\n");
Sleep(800);
}
else
{
printf("\n");
printf("你的通讯录里面有此联系人,它的信息是:>\n");
Show_Person_Information(List, ret);
Sleep(800);
}
}
void Modify_Linkman_Information(struct Adress_List* List)
{
printf("请输入你想修改信息的联系人的姓名:>");
char name[MAX_NAME];
scanf("%s", name);
int ret = Find_By_Name(List, name);
if (-1 == ret)
{
printf("此联系人不存在!\n");
Sleep(800);
}
else
{
printf("请输入名字:>");
scanf("%s", List->data[ret].name);
printf("请输入性别:>");
scanf("%s", List->data[ret].sex);
printf("请输入电话:>");
scanf("%s", List->data[ret].phone);
printf("请输入年龄:>");
scanf("%d", &List->data[ret].age);
printf("请输入家庭住址:>");
scanf("%s", List->data[ret].adress);
printf("修改成功!\n");
printf("\n");
Sleep(800);
}
}
void SortList_By_age(const struct Adress_List* List)
{
assert(List);
if (List->size <= 1)
{
printf("\n");
printf("通讯录里面联系人个数小于两个没有必要对其进行排序!\n");
Sleep(800);
return;
}
qsort(List->data, List->size, sizeof(struct Person_Information), compare);
printf("排序完成!\n");
Sleep(800);
}
void Delete_AllLinkman(struct Adress_List* List)
{
if (List->size == 0)
{
printf("通讯录为空,无法操作!\n");
Sleep(800);
}
else
{
struct Person_Information Delete[MAX];
int i = 0;
int k = List->size;
for (i = 0; i < k; i++)
{
Delete[i] = List->data[i];
List->size--;
}
printf("删除成功!\n");
Sleep(800);
}
}
void Destory_Adress_List(struct Adress_List* List)
{
assert(List);
free(List->data);
List->data = NULL;
List->size = 0;
List->capacity = 0;
}
HiddenFunction.c文件
#define _CRT_SECURE_NO_WARNINGS 1
#include "Dynamic_AdressList.h"
int Find_By_Name(const struct Adress_List* List, char name[])
{
int i = 0;
for (i = 0; i < List->size; i++)
{
if (0 == strcmp(List->data[i].name, name))
{
return i;
}
}
return -1;
}
int compare(const void* e1, const void* e2)
{
return ((struct Person_Information*)e1)->age - ((struct Person_Information*)e2)->age;
}
void Show_Person_Information(struct Adress_List* List, int ret)
{
printf("-------------------------------------------------------------------------------\n");
printf("%-5s\t%-5s\t%-15s\t%-20s\t%-20s\n", "姓名", "性别", "电话", "年龄", "家庭住址");
printf("%-5s\t%-5s\t%-15s\t%-20d\t%-20s\n",
List->data[ret].name,
List->data[ret].sex,
List->data[ret].phone,
List->data[ret].age,
List->data[ret].adress);
printf("-------------------------------------------------------------------------------\n");
printf("\n");
}
int Judge_Capactiy(struct Adress_List* List)
{
if (List->size == List->capacity)
{
struct Person_Information* information_capacity = (struct Person_Information*)realloc(List->data, (List->capacity + 2) * sizeof(struct Person_Information));
if (information_capacity == NULL)
{
perror("Add_Linkman:Judge_Capactiy()");
Sleep(1000);
return 0;
}
else
{
List->data = information_capacity;
List->capacity = List->capacity + ADD_CAPACITY_LIMIT;
return 1;
}
}
else
{
return 1;
}
}
Dynamic_AdressList.h文件
#pragma once
#include <stdio.h>
#include <assert.h>
#include <string.h>
#include <stdlib.h>
#include <Windows.h>
#define MAX 100
#define MAX_NAME 10
#define MAX_SEX 5
#define MAX_PONE 15
#define MAX_ADRESS 20
#define MAX_CAPACITY 3
#define ADD_CAPACITY_LIMIT 2
struct Person_Information
{
char name[MAX_NAME];
char sex[MAX_SEX];
char phone[MAX_PONE];
int age;
char adress[MAX_ADRESS];
};
struct Adress_List
{
struct Person_Information* data;
int size;
int capacity;
};
void Init_Adress_List(struct Adress_List* List);
void menu();
void Add_Linkman(struct Adress_List* List);
int Judge_Capactiy(struct Adress_List* List);
void Show_Adress_List(const struct Adress_List* List);
void Delete_Linkman(struct Adress_List* List);
int Find_By_Name(const struct Adress_List* List, char name[]);
void Show_Person_Information(struct Adress_List* List, int ret);
void Find_Linkman(struct Adress_List* List);
void Modify_Linkman_Information(struct Adress_List* List);
void SortList_By_age(const struct Adress_List* List);
int compare(const void* e1, const void* e2);
void Delete_AllLinkman(struct Adress_List* List);
void Destory_Adress_List(struct Adress_List* List);
介绍完毕,感谢支持!争取写出更优秀的博客!
|