最终版通讯录即从上一个版本修改过来

先看总体代码,我们再看看差异

ps:里面涉及到很多函数的使用,后续我会出专栏来书写这些函数的使用和实例,与常见错误

大家可以通过https://cplusplus.com查找

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.alter       *****\n");printf("*****    5.show     6.empty       *****\n");printf("*****    7.sort     0.exit        *****\n");printf("***************************************\n");}enum Function
{EXIT,ADD,DEL,SEARCH,ALTER,SHOW,EMPTY,SORT
};int main()
{int input = 0;//创建结构体Contact con;//初始化IntiContact(&con);//加载通讯录LoadContact(&con);do{menu();scanf("%d", &input);switch (input){case ADD : AddContact(&con);break;case DEL : DelContact(&con);break;case SEARCH: SearchContact(&con);break;case ALTER: AlterContact(&con);break;case SHOW: ShowContact(&con);break;case EMPTY: EmptyContact(&con);break;case SORT: qsort(con.data, con.sz, sizeof(PeoInfo), Contact_sort_name);printf("排序成功\n");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#define _CRT_SECURE_NO_WARNINGS 1#include "Contact.h"//静态版本
//void IntiContact(Contact* pc)//初始化电话簿
//{
//    pc->sz = 0;
//    memset(pc->data, 0, sizeof(pc->data));
//}//动态版本
void IntiContact(Contact* pc)//初始化电话簿
{pc->sz = 0;PeoInfo* ptr = (PeoInfo*)calloc(Capatify_Inti, sizeof(PeoInfo));if (ptr == NULL){perror("IntiContact::calloc");return;}pc->data = ptr;pc->capatify = Capatify_Inti;}//静态版本
//void AddContact(Contact* pc)//增加联系人
//{
//    if (pc->sz == num)
//    {
//        printf("通讯录已经满了\n");
//        return;
//    }
//
//    printf("请输入姓名\n");
//    scanf("%s", pc->data[pc->sz].name);
//
//    printf("请输入性别\n");
//    scanf("%s", pc->data[pc->sz].sex);
//
//    printf("请输入年龄\n");
//    scanf("%d", &(pc->data[pc->sz].age));
//
//    printf("请输入电话\n");
//    scanf("%s", pc->data[pc->sz].tel);
//
//    printf("请输入地址\n");
//    scanf("%s", pc->data[pc->sz].address);
//
//    pc->sz++;
//
//}void check_capatify(Contact* pc)
{if (pc->sz == pc->capatify){PeoInfo* ptr = (PeoInfo*)realloc(pc->data, (pc->capatify + Capatify_ADD) * sizeof(PeoInfo));if (ptr == NULL){perror("check_capatify::realloc");return;}pc->data = ptr;pc->capatify += Capatify_ADD;printf("增容成功\n");}
}void DestroyContact(Contact* pc)
{free(pc->data);pc->data = NULL;pc->capatify = 0;pc->sz = 0;pc = NULL;
}void AddContact(Contact* pc)//增加联系人
{check_capatify(pc);printf("请输入姓名\n");scanf("%s", pc->data[pc->sz].name);printf("请输入性别\n");scanf("%s", pc->data[pc->sz].sex);printf("请输入年龄\n");scanf("%d", &(pc->data[pc->sz].age));printf("请输入电话\n");scanf("%s", pc->data[pc->sz].tel);printf("请输入地址\n");scanf("%s", pc->data[pc->sz].address);pc->sz++;}void ShowContact(Contact* pc)//展示电话簿
{int i = 0;printf("%-20s\t%-5s\t%-3s\t%-12s\t%-20s\n", "姓名", "性别", "年龄", "电话", "地址");for (i = 0; i < pc->sz; i++){printf("%-20s\t%-5s\t%-3d\t%-12s\t%-20s\n",pc->data[i].name,pc->data[i].sex,pc->data[i].age,pc->data[i].tel,pc->data[i].address);}
}int FindName(Contact* pc, char 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(Contact* pc)//删除联系人
{if (pc->sz == 0){printf("通讯录没有联系人,无法删除\n");return;}char name[20];printf("请输入要删除的名字\n");scanf("%s", name);int ret = FindName(pc, name);if (ret == -1){printf("查无此人\n");return;}int i = 0;for (i = ret; i < pc->sz - 1; i++){pc->data[i] = pc->data[i + 1];}pc->sz--;printf("删除成功\n");
}void SearchContact(Contact* pc)//搜索联系人
{char name[20];printf("请输入要查找的联系人\n");scanf("%s", name);int ret = FindName(pc, name);if (ret == -1){printf("没有该联系人\n");return;}printf("%-20s\t%-5s\t%-3s\t%-12s\t%-20s\n", "姓名", "性别", "年龄", "电话", "地址");printf("%-20s\t%-5s\t%-3d\t%-12s\t%-20s\n",pc->data[ret].name,pc->data[ret].sex,pc->data[ret].age,pc->data[ret].tel,pc->data[ret].address);
}void AlterContact(Contact* pc)
{printf("请输入要修改人的名字\n");char name[20];scanf("%s", name);int ret = FindName(pc, name);if (ret == -1){printf("电话簿没有此人\n");return;}printf("请输入新姓名\n");scanf("%s", pc->data[ret].name);printf("请输入新性别\n");scanf("%s", pc->data[ret].sex);printf("请输入新年龄\n");scanf("%d", &(pc->data[ret].age));printf("请输入新电话\n");scanf("%s", pc->data[ret].tel);printf("请输入新地址\n");scanf("%s", pc->data[ret].address);printf("修改成功\n");}void EmptyContact(Contact* pc)//清空电话簿
{pc->sz = 0;memset(pc->data, 0, sizeof(pc->data));printf("清空电话簿成功\n");
}int Contact_sort_name(void* e1, void* e2)
{return strcmp((Contact*)e1, (Contact*)e2);
}void SaveContact(Contact* pc)
{FILE* pf = fopen("Contact.txt", "wb");if (NULL == pf){perror("SaveContact::fopen");}else{int i = 0;for (i = 0; i < pc->sz; i++){fwrite(pc->data+i, sizeof(PeoInfo), 1, pf);}fclose(pf);pf = NULL;printf("保存成功\n");}}void LoadContact(Contact* pc)
{FILE* pf = fopen("Contact.txt", "rb");if (NULL == pf){perror("LoadContact::fopen");}else{int i = 0;while (fread(pc->data+i, sizeof(PeoInfo), 1, pf)){check_capatify(pc);i++;pc->sz++;}fclose(pf);pf = NULL;}
}

Contact.h

#pragma once#pragma once#include <stdio.h>
#include <string.h>
#include <stdlib.h>#define num 1000
#define num_name 20
#define num_sex 5
#define num_tel 20
#define num_address 30
#define Capatify_Inti 3
#define Capatify_ADD 2typedef struct PeoInfo
{char name[num_name];char sex[num_sex];int age;char tel[num_tel];char address[num_address];
}PeoInfo;//静态版本
//typedef struct Contact
//{
//    PeoInfo data[num];//联系人数量
//    int sz;//存有联系人数量
//}Contact;//动态版本
typedef struct Contact
{PeoInfo* data;//联系人数量int sz;//存有联系人数量int capatify;//容量
}Contact;void IntiContact(Contact* pc);//初始化void DestroyContact(Contact* pc);//销毁通讯录void AddContact(Contact* pc);//增加联系人void ShowContact(Contact* pc);//展示电话簿void DelContact(Contact* pc);//删除联系人void SearchContact(Contact* pc);//搜索联系人void EmptyContact(Contact* pc);//清空电话簿int Contact_sort_name(void* e1, void* e2);//qsortvoid SaveContact(Contact* pc);//保存通讯录void LoadContact(Contact* pc);//加载通讯录

我们添加了,枚举

枚举我们使用的枚举的常量,使用枚举,我们可以清楚的知道,case 之后数字的功能

动态的通讯录,我们是随着通讯录联系人数量的增加,然后使用calloc函数开辟空间,这样可以减少空间的浪费

我们初始化时给定联系人限定值,然后增加联系人前,判断达到了限定值,然后重新开辟空间使用reaccol

开辟好了内存空间,下面就到了增加联系人

//静态版本
//void AddContact(Contact* pc)//增加联系人
//{
//    if (pc->sz == num)
//    {
//        printf("通讯录已经满了\n");
//        return;
//    }
//
//    printf("请输入姓名\n");
//    scanf("%s", pc->data[pc->sz].name);
//
//    printf("请输入性别\n");
//    scanf("%s", pc->data[pc->sz].sex);
//
//    printf("请输入年龄\n");
//    scanf("%d", &(pc->data[pc->sz].age));
//
//    printf("请输入电话\n");
//    scanf("%s", pc->data[pc->sz].tel);
//
//    printf("请输入地址\n");
//    scanf("%s", pc->data[pc->sz].address);
//
//    pc->sz++;
//
//}void check_capatify(Contact* pc)
{if (pc->sz == pc->capatify){PeoInfo* ptr = (PeoInfo*)realloc(pc->data, (pc->capatify + Capatify_ADD) * sizeof(PeoInfo));if (ptr == NULL){perror("check_capatify::realloc");return;}pc->data = ptr;pc->capatify += Capatify_ADD;printf("增容成功\n");}
}void AddContact(Contact* pc)//增加联系人
{check_capatify(pc);printf("请输入姓名\n");scanf("%s", pc->data[pc->sz].name);printf("请输入性别\n");scanf("%s", pc->data[pc->sz].sex);printf("请输入年龄\n");scanf("%d", &(pc->data[pc->sz].age));printf("请输入电话\n");scanf("%s", pc->data[pc->sz].tel);printf("请输入地址\n");scanf("%s", pc->data[pc->sz].address);pc->sz++;}

静态版本我们限定了数量

动态版本我们增加联系人前,需要检查我们通讯录联系人数量和通讯录容量大小,看看还能放下联系人吗,如果不能放下,联系人数量=通讯录容量,我们就使用realloc增加空间,然后改变容量,这样我们才能放下增加的联系人

void SaveContact(Contact* pc)
{FILE* pf = fopen("Contact.txt", "wb");if (NULL == pf){perror("SaveContact::fopen");}else{int i = 0;for (i = 0; i < pc->sz; i++){fwrite(pc->data+i, sizeof(PeoInfo), 1, pf);}fclose(pf);pf = NULL;printf("保存成功\n");}}

我们打开通讯录的时候应该加载之前保存的通讯录内容

void LoadContact(Contact* pc)
{FILE* pf = fopen("Contact.txt", "rb");if (NULL == pf){perror("LoadContact::fopen");}else{int i = 0;while (fread(pc->data+i, sizeof(PeoInfo), 1, pf)){check_capatify(pc);i++;pc->sz++;}fclose(pf);pf = NULL;}
}

通讯录最终版——动态存储+文件处理相关推荐

  1. 文件存储php源码,FFS5-Mini v120731 最终版 php网络文件存储分享系统

    FFS是一款基于PHP+多重数据库的先进的网络文件存储分享系统,通过本系统,用户可以将资料在线上传到您的系统中,独创的文件分享码模式,轻松分享每一个文件.更有丰富多彩的文件应用提升文件的价值. FFS ...

  2. C语言小项目 -- 通讯录(静态版+动态版+文件版)

    文章目录 一.总体设计思路 1.设计背景 2.设计框架 3.功能概述 二.通讯录(静态版) 1.结构体设计 2.初始化通讯录 3.添加联系人信息 4.删除联系人信息 5.查找联系人(按姓名) 6.查找 ...

  3. C语言版动态通讯录(增、删、改、查(查重)、去重、排序、导出)

    C语言版动态通讯录(增.删.改.查(查重).去重.排序.导出) 一段学习过后,想写小东西加深下印象和理解,便开始了我的动态通讯录之旅. 整体框架及实现 通讯录主体 typedef struct con ...

  4. 驱动精灵 v9.61 去广告最终版绿色清爽单文件

    驱动精灵,驱动研究专注不怠,只为解决驱动问题!驱动精灵是集驱动管理和硬件检测于一体.专业级的驱动管理维护工具.它提供驱动备份.恢复.安装.删除.在线更新等实用功能.驱动精灵秉承驱动之家十余年积累,硬件 ...

  5. C语言题目——通讯录(静态存储+动态存储)

    目录 通讯录基本要求: 实现功能: 一.打印菜单: 二.联系人信息存储 三.通讯录初始化及功能: 1.静态存储通讯录 (1).通讯录信息: (2).初始化通讯录: (3).通讯录功能: 2.动态存储通 ...

  6. 文件密码锁最终版-Bat格式

    文件密码锁最终版-Bat格式 操作步骤: 1.在随便一个地方,鼠标右击空白处选择[新建]-->[文本文档] 2.在文本中输入普通的锁屏代码(可以自己修改加些不一样的东西) 打完那个代码后,把要隐 ...

  7. 版本 3.1(最终版)

    1 Java™ Servlet 规范 版本 3.1(最终版) Shing Wai Chan Rajiv Mordani [作者] 穆茂强 张开涛 [译者] 2012 年 6 月翻译 2013 年 7 ...

  8. 你好,offer(最终版)

    你好,offer(最终版) 计算机网络 osi七层模型:物联网叔会试用 物理层 链路层 网络层 传输层 会话层 表示层 应用层 五层协议 UDP相关 TCP相关 TCP的三从握手和四次挥手 三次握手 ...

  9. c语言编程的电压表设计,简易数字直流电压表的设计(最终版)最新版

    <简易数字直流电压表的设计.doc>由会员分享,可免费在线阅读全文,更多与<简易数字直流电压表的设计(最终版)>相关文档资源请在帮帮文库(www.woc88.com)数亿文档库 ...

最新文章

  1. 算法基础知识科普:8大搜索算法之红黑树(下)
  2. 用产品的心态写代码:什么样的机器学习产品是最符合用户需求的
  3. Linux下的静态库、动态库和动态加载库
  4. 修改gitlib默认master受保护分支
  5. 看设备指示灯识别网络故障
  6. Apache Jakarta Commons 工具集简介
  7. CST光源控制卡简单操作C#程序
  8. springcloud官方文档_通俗易懂!Spring Cloud简介:官方文档翻译版
  9. DOM(四)——事件、事件模型(冒泡)与事件对象的功能
  10. 带你了解 HBase 数据模型和 HBase 架构
  11. Spark internal - 多样化的运行模式 (下)
  12. windows聚焦壁纸不更新_锁屏壁纸windows聚焦不更新?
  13. scala 如何读取 csv 文件
  14. 约瑟夫环 java_约瑟夫环的java实现
  15. android mac地址不可用,Android手机里的mac地址显示不可用是为什么。我的手机是海信E920....
  16. 水火箭的工作原理(化学反应)//2021-2-24 从群众中来,到群众中去
  17. 正确的洗澡顺序,据说99%的人都是错的。。
  18. 日语学习的一些网站推荐
  19. pygame安装(2020版超详细)
  20. [Mysql] PERCENT_RANK()函数 | CUME_DIST()函数

热门文章

  1. mysql数据库成绩数据类型_mysql数据库基本数据类型
  2. Zynq+zcu106学习随笔3-搭建pateLinux
  3. java炮弹_Java坦克大战 (四) 之子弹的产生
  4. SQL Server常用语句
  5. 率土之滨显示没选择服务器,率土之滨 这些实用攻略还不知道你就OUT啦
  6. 解决电动车使用焦虑:蔚来发布NIO Power 2025换电站布局计划
  7. 大数据JavaWeb之MySQL基础---数据库设计、备份与还原
  8. 联想企业网盘助力中信证券上云,打造云中最美团队
  9. c语言while嵌套循环语句,C语言 while 循环嵌套-嗨客网
  10. 【Vue已解决】当点击某个遍历出来的元素并修改背景颜色且唯一,通过ref获取dom节点再操作