通讯录管理系统<C/C++>(万字详解/文末源码)(1)

简介: 通讯录管理系统<C/C++>(万字详解/文末源码)(1)

0、内容介绍

本篇文章中博主给大家带来了万字级通讯录项目详解,并且给出了源代码及代码段详解,建议大家点赞收藏后食用哦!

1、系统需求

通讯录是一个可以记录亲人、好友信息的工具。


本教程主要利用C++来实现一个通讯录管理系统


系统中需要实现的功能如下:


添加联系人:向通讯录中添加新人,信息包括(姓名、性别、年龄、联系电话、家庭住址)最多记录1000人


显示联系人:显示通讯录中所有联系人信息


删除联系人:按照姓名进行删除指定联系人


查找联系人:按照姓名查看指定联系人信息


修改联系人:按照姓名重新修改指定联系人


清空联系人:清空通讯录中所有信息


退出通讯录:退出当前使用的通讯录

2、创建项目

创建项目步骤如下:

  • 创建项目
  • 添加源文件

2.1、创建项目

首先打开vs,点击创建新项目即可

填写项目名称(这里为了方便大家看到,我是直接用的中文,但是大家请注意,在正规的项目中,项目名一定要不要用中文,防止出现乱码等情况),选择项目路径

2.2、添加文件

好啦,现在项目已经创建完毕,我们剩下的的任务就是问题分析 & 敲代码了。

3、菜单选择

功能描述 :

       用户选择功能的界面

菜单界面效果示意图如下:

实现步骤:

  • 封装函数显示该界面  
  • 在main函数中调用封装好的函数

代码

#include<iostream>
using namespace std;
//菜单界面
void showMenu()
{
  cout << "***************************" << endl;
  cout << "*****  1、添加联系人  *****" << endl;
  cout << "*****  2、显示联系人  *****" << endl;
  cout << "*****  3、删除联系人  *****" << endl;
  cout << "*****  4、查找联系人  *****" << endl;
  cout << "*****  5、修改联系人  *****" << endl;
  cout << "*****  6、清空联系人  *****" << endl;
  cout << "*****  0、退出通讯录  *****" << endl;
  cout << "***************************" << endl;
}
int main() {
  showMenu();
  system("pause");//按任意键继续
  return 0;
}
```

4、退出功能

功能描述

       退出通讯录系统

思路

      根据用户不同的选择,进入不同的功能,可以选择switch分支结构,将整个架构进行搭建

     当用户选择0时候,执行退出,选择其他先不做操作,也不会退出程序

int main() {
  int select = 0;
//给一个循环,当我们执行完对应的操作后跳出
  while (true)
  {
    showMenu();
    cin >> select;
    switch (select)
    {
    case 1:  //添加联系人
      break;
    case 2:  //显示联系人
      break;
    case 3:  //删除联系人
      break;
    case 4:  //查找联系人
      break;
    case 5:  //修改联系人
      break;
    case 6:  //清空联系人
      break;
    case 0:  //退出通讯录
      cout << "欢迎下次使用" << endl;
      system("pause");
      return 0;
      break;
    default:
      break;
    }
  }
  system("pause");
  return 0;
}


5、添加联系人

功能描述:

实现添加联系人功能,联系人上限为1000人,联系人信息包括(姓名、性别、年龄、联系电话、家庭住址)

添加联系人实现步骤:

  • 设计联系人结构体
  • 设计通讯录结构体
  • main函数中创建通讯录
  • 封装添加联系人函数
  • 测试添加联系人功能

5.1、设计联系人结构体

联系人信息包括:姓名、性别、年龄、联系电话、家庭住址

联系人结构体代码

#include <string>  //string头文件
//联系人结构体
struct Person
{
  string m_Name; //姓名
  int m_Sex; //性别:1男 2女
  int m_Age; //年龄
  string m_Phone; //电话
  string m_Addr; //住址
};

5.2、设计通讯录结构体

设计时候可以在通讯录结构体中,维护一个容量为1000的存放联系人的数组,

并记录当前通讯录中联系人数量


通讯录结构体代码

#define MAX 1000 //最大人数
//通讯录结构体
struct Addressbooks
{
  struct Person personArray[MAX]; //通讯录中保存的联系人数组
  int m_Size; //通讯录中人员个数
};

这里对于最大人数我用的是宏定义,方便以后对这个通讯录扩容


5.3、在main函数中创建通讯录

添加联系人函数封装好后,在main函数中创建一个通讯录变量,

这个就是我们需要一直维护的通讯录


创建通讯录代码

//mian函数起始位置添加:
  //创建通讯录
  Addressbooks abs;
  //初始化通讯录中人数
  abs.m_Size = 0;

5.4、封装添加联系人函数

思路:

       添加联系人前先判断通讯录是否已满,如果满了就不再添加,

       未满情况将新联系人信息逐个加入到通讯录


添加联系人代码:

//1、添加联系人信息
void addPerson(Addressbooks *abs)
{
  //判断电话本是否满了
  if (abs->m_Size == MAX)
  {
    cout << "通讯录已满,无法添加" << endl;
    return;
  }
  else
  {
    //姓名
    string name;
    cout << "请输入姓名:" << endl;
    cin >> name;
    abs->personArray[abs->m_Size].m_Name = name;
    cout << "请输入性别:" << endl;
    cout << "1 -- 男" << endl;
    cout << "2 -- 女" << endl;
    //性别
    int sex = 0;
    while (true)
    {
      cin >> sex;
      if (sex == 1 || sex == 2)
      {
        abs->personArray[abs->m_Size].m_Sex = sex;
        break;
      }
      cout << "输入有误,请重新输入";
    }
    //年龄
    cout << "请输入年龄:" << endl;
    int age = 0;
    cin >> age;
    abs->personArray[abs->m_Size].m_Age = age;
    //联系电话
    cout << "请输入联系电话:" << endl;
    string phone = "";
    cin >> phone;
    abs->personArray[abs->m_Size].m_Phone = phone;
    //家庭住址
    cout << "请输入家庭住址:" << endl;
    string address;
    cin >> address;
    abs->personArray[abs->m_Size].m_Addr = address;
    //更新通讯录人数
    abs->m_Size++;
    cout << "添加成功" << endl;
    system("pause");
    system("cls");
  }
}

5.5、测试添加联系人功能

随着我们编写代码的长度的增加,我们出现错误的概率也会增加,这时我们最好每写完一段代码就对代码进行测试,切忌上来“咔咔咔”一顿操作猛如虎,一运行一堆报错,功能也对不上,改的话又过于繁琐,倒不如一段一段测试。

选择界面中,如果玩家选择了1,代表添加联系人,我们可以测试下该功能

测试代码

在switch case 语句中,case1里添加:

case 1:  //添加联系人
  addPerson(&abs);
  break;

相关文章
|
2月前
|
C++
基本二叉树与排序二叉树(C++源码)
本程序实现二叉树基本操作与二叉排序树应用。支持前序建树、四种遍历、求深度、叶子数、第K层节点数及查找功能;并实现二叉排序树的构建、中序输出与查找比较次数统计,分析不同插入顺序对树形态和查找效率的影响。
|
9月前
|
编译器 C++ 容器
【c++丨STL】基于红黑树模拟实现set和map(附源码)
本文基于红黑树的实现,模拟了STL中的`set`和`map`容器。通过封装同一棵红黑树并进行适配修改,实现了两种容器的功能。主要步骤包括:1) 修改红黑树节点结构以支持不同数据类型;2) 使用仿函数适配键值比较逻辑;3) 实现双向迭代器支持遍历操作;4) 封装`insert`、`find`等接口,并为`map`实现`operator[]`。最终,通过测试代码验证了功能的正确性。此实现减少了代码冗余,展示了模板与仿函数的强大灵活性。
255 2
|
10月前
|
存储 监控 算法
员工屏幕监控系统之 C++ 图像差分算法
在现代企业管理中,员工屏幕监控系统至关重要。本文探讨了其中常用的图像差分算法,该算法通过比较相邻两帧图像的像素差异,检测屏幕内容变化,如应用程序切换等。文中提供了C++实现代码,并介绍了其在实时监控、异常行为检测和数据压缩等方面的应用,展示了其实现简单、效率高的特点。
300 15
|
12月前
|
编译器 C语言 C++
【c++丨STL】list模拟实现(附源码)
本文介绍了如何模拟实现C++中的`list`容器。`list`底层采用双向带头循环链表结构,相较于`vector`和`string`更为复杂。文章首先回顾了`list`的基本结构和常用接口,然后详细讲解了节点、迭代器及容器的实现过程。 最终,通过这些步骤,我们成功模拟实现了`list`容器的功能。文章最后提供了完整的代码实现,并简要总结了实现过程中的关键点。 如果你对双向链表或`list`的底层实现感兴趣,建议先掌握相关基础知识后再阅读本文,以便更好地理解内容。
260 1
|
C语言 C++ 容器
【c++丨STL】string模拟实现(附源码)
本文详细介绍了如何模拟实现C++ STL中的`string`类,包括其构造函数、拷贝构造、赋值重载、析构函数等基本功能,以及字符串的插入、删除、查找、比较等操作。文章还展示了如何实现输入输出流操作符,使自定义的`string`类能够方便地与`cin`和`cout`配合使用。通过这些实现,读者不仅能加深对`string`类的理解,还能提升对C++编程技巧的掌握。
511 5
|
存储 编译器 C++
【C++篇】揭开 C++ STL list 容器的神秘面纱:从底层设计到高效应用的全景解析(附源码)
【C++篇】揭开 C++ STL list 容器的神秘面纱:从底层设计到高效应用的全景解析(附源码)
236 2
|
C++
【C++案例】一个项目掌握C++基础-通讯录管理系统
这篇文章通过一个通讯录管理系统的C++项目案例,详细介绍了如何使用C++实现添加、显示、删除、查找、修改和清空联系人等功能。
289 3
|
存储 数据可视化 C++
【C++】C++-学生考试题库管理系统(源码)
本系统设计了一个选题管理流程,包括读取题目信息、随机抽取题目、保存及查询选题结果等功能。使用 `readProjects` 从文件读取题目信息,`drawProject` 随机抽取未选中的题目,`saveSelection` 保存选题结果至文件,`querySelection` 查询并显示所有选题结果。主函数提供菜单界面,支持学生信息输入、抽题及结果查询。关注【测试开发自动化】公众号,回复“题库”获取源码。
197 1
|
Rust 安全 C++
系统编程的未来之战:Rust能否撼动C++的王座?
【8月更文挑战第31天】Rust与C++:现代系统编程的新选择。C++长期主导系统编程,但内存安全问题频发。Rust以安全性为核心,通过所有权和生命周期概念避免内存泄漏和野指针等问题。Rust在编译时确保内存安全,简化并发编程,其生态系统虽不及C++成熟,但发展迅速,为现代系统编程提供了新选择。未来有望看到更多Rust驱动的系统级应用。
321 1
|
10月前
|
编译器 C++ 开发者
【C++篇】深度解析类与对象(下)
在上一篇博客中,我们学习了C++的基础类与对象概念,包括类的定义、对象的使用和构造函数的作用。在这一篇,我们将深入探讨C++类的一些重要特性,如构造函数的高级用法、类型转换、static成员、友元、内部类、匿名对象,以及对象拷贝优化等。这些内容可以帮助你更好地理解和应用面向对象编程的核心理念,提升代码的健壮性、灵活性和可维护性。