C++如何实现简易通讯录功能

答案是使用C++中的结构体和vector实现通讯录,通过菜单操作添加、查看和查找联系人。定义Contact结构体存储姓名和电话,利用std::vector管理联系人列表,提供添加、显示全部和按姓名查找的功能,结合命令行交互完成简易通讯录的核心逻辑。

c++如何实现简易通讯录功能

C++实现一个简易通讯录功能,核心在于选择合适的数据结构来存储联系人信息,并围绕这个数据结构构建添加、查找、删除等基本操作。通常,我们会用到结构体(

struct

)来定义联系人,然后将其放入一个动态数组(如

std::vector

)中进行管理,再通过一个简单的命令行菜单来与用户交互。这听起来可能有点像搭积木,但每一步的选择都直接影响最终的可用性。

解决方案:在我看来,实现一个简易通讯录,最直观且易于上手的方式,就是定义一个

Contact

结构体来承载每个联系人的基本信息,比如姓名和电话号码。然后,我们用

std::vector

来存储这些联系人。这样一来,动态增删联系人就变得非常方便。

首先,我们定义联系人的结构:

#include #include #include #include  // For numeric_limits// 定义联系人结构struct Contact {    std::string name;    std::string phone;    // 构造函数,方便初始化    Contact(std::string n, std::string p) : name(std::move(n)), phone(std::move(p)) {}    // 打印联系人信息    void display() const {        std::cout << "姓名: " << name << ", 电话: " << phone << std::endl;    }};// 全局向量来存储所有联系人std::vector contacts;// 添加联系人void addContact() {    std::string name, phone;    std::cout << "请输入联系人姓名: ";    // 清除输入缓冲区,防止getline读取到之前的换行符    std::cin.ignore(std::numeric_limits::max(), 'n');    std::getline(std::cin, name);    std::cout << "请输入联系人电话: ";    std::getline(std::cin, phone);    contacts.emplace_back(name, phone);    std::cout << "联系人添加成功!" << std::endl;}// 查看所有联系人void viewContacts() {    if (contacts.empty()) {        std::cout << "通讯录为空。" << std::endl;        return;    }    std::cout << "n--- 通讯录列表 ---" << std::endl;    for (const auto& contact : contacts) {        contact.display();    }    std::cout << "------------------n" << std::endl;}// 查找联系人void searchContact() {    if (contacts.empty()) {        std::cout << "通讯录为空,无法查找。" << std::endl;        return;    }    std::string nameToSearch;    std::cout << "请输入要查找的联系人姓名: ";    std::cin.ignore(std::numeric_limits::max(), 'n');    std::getline(std::cin, nameToSearch);    bool found = false;    std::cout << "n--- 查找结果 ---" << std::endl;    for (const auto& contact : contacts) {        if (contact.name == nameToSearch) {            contact.display();            found = true;        }    }    if (!found) {        std::cout << "未找到姓名为 '" << nameToSearch << "' 的联系人。" << std::endl

以上就是C++如何实现简易通讯录功能的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1476223.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 00:04:03
下一篇 2025年12月19日 00:04:16

相关推荐

  • c++中如何判断文件是否存在_C++检查文件存在性的方法

    c++kquote>答案是使用C++17的std::filesystem::exists最推荐,跨平台且简洁;否则可用std::ifstream尝试打开文件作为兼容方案。 在C++中判断文件是否存在,有多种方法可以实现,常用的方式依赖于标准库或操作系统相关的API。以下是几种实用且跨平台兼容性…

    2025年12月19日
    000
  • C++数组和指针在函数参数中传递

    C++中数组和指针作函数参数时传递的是首元素地址,修改会影响原数组;常见方式包括传数组名(转指针)、传指针、传数组引用、std::vector引用及指向数组的指针,其中推荐使用std::vector以提升安全性和灵活性。 C++中,数组和指针作为函数参数传递时,实际上传递的是数组首元素的地址,而不是…

    2025年12月19日
    000
  • C++多线程任务划分与性能优化

    C++多线程任务划分需根据CPU核心数、任务类型选择线程数量,采用静态或动态划分策略,结合无锁结构、减少同步开销、避免伪共享,并使用线程池和性能分析工具优化整体性能。 C++多线程任务划分的核心在于如何将一个大的计算任务拆分成多个小任务,并合理地分配给多个线程并行执行,从而缩短总的执行时间。性能优化…

    2025年12月19日
    000
  • C++观察者模式与线程安全结合使用

    线程安全的观察者模式需用互斥锁保护共享状态,避免多线程下注册、注销或通知时的数据竞争。1. 使用std::lock_guard确保attach、detach和notify对观察者列表的操作原子性;2. notify中先复制列表再释放锁,防止回调期间持有锁导致死锁或迭代器失效;3. 建议使用std::…

    2025年12月19日
    000
  • c++中如何使用构造函数_C++类的构造函数使用方法与规则

    构造函数用于初始化类对象,创建实例时自动调用。其名称与类名相同,无返回类型,可重载并支持默认、带参和拷贝形式。推荐使用初始化列表提高效率,explicit关键字防止隐式转换,合理使用可提升代码安全与性能。 在C++中,构造函数是一种特殊的成员函数,用于初始化类的对象。当创建类的实例时,构造函数会自动…

    2025年12月19日
    000
  • c++中如何将数字转换为十六进制字符串_数字与十六进制字符串转换技巧

    答案是使用std::stringstream结合std::hex和std::uppercase可将数字转为十六进制字符串。示例代码包含头文件、定义toHex函数,通过ss 在C++中,将数字转换为十六进制字符串是一个常见的需求,尤其是在处理内存地址、颜色值或底层数据时。C++提供了多种方式来实现这一…

    2025年12月19日
    000
  • C++初级项目如何实现文件读写功能

    C++初级项目实现文件读写需包含头文件,使用std::ofstream写入、std::ifstream读取、std::fstream同时读写;操作前应检查is_open()状态,文本文件用 C++初级项目里想实现文件读写功能,其实并不复杂,核心就是利用标准库里的 fstream 头文件,通过 ifs…

    2025年12月19日
    000
  • 如何在C++中遍历一个文件夹中的所有文件_C++目录文件遍历实现

    C++中遍历文件夹需根据操作系统选择POSIX或Windows API方法,前者使用dirent.h读取目录项并递归处理子目录,后者通过FindFirstFile/FindNextFile实现类似功能;为避免无限循环需跳过”.”和”..”;可结合acc…

    2025年12月19日
    000
  • c++如何进行位操作_c++位运算符与高效位运算技巧

    C++中常用的位运算符有六种:&amp;(按位与)用于掩码和提取位,|(按位或)用于设置位,^(按位异或)用于翻转位,~(按位取反)用于反转所有位,(右移)用于快速除以2的幂;它们共同支持高效的数据操作、状态管理和性能优化,广泛应用于底层编程和算法设计。 C++进行位操作的核心在于直接操纵数…

    2025年12月19日
    000
  • C++数组初始化与指针偏移访问

    数组初始化有多种方式,如全显式、部分、省略大小和全零初始化;数组名是首元素地址的常量指针,可用指针偏移访问元素,*(arr + i) 等价于 arr[i];指针变量可指向数组并访问,但数组名不可重新赋值,动态数组用 new 创建。 在C++中,数组和指针密切相关。理解数组如何初始化以及如何通过指作为…

    2025年12月19日
    000
  • C++如何在模板中使用静态成员变量

    必须显式定义模板静态成员变量,否则引发链接错误;例如声明为static T value;后需在类外定义T MyClass::value = T(); 每个模板实例拥有独立静态变量;C++17起可用inline static简化处理,避免额外定义。 在C++模板中使用静态成员变量时,需要特别注意其声明…

    2025年12月19日
    000
  • c++中如何初始化vector_C++ vector容器初始化方法大全

    C++中vector初始化方法包括:1. 默认初始化创建空vector;2. 指定大小,元素默认初始化;3. 指定大小和初始值;4. 使用花括号列表初始化;5. 拷贝构造;6. 迭代器区间初始化;7. assign方法赋值;8. 复杂类型列表构造;9. 动态分配(不推荐)。 在C++中,vector…

    2025年12月19日
    000
  • C++如何打开文本文件进行读取

    首先包含fstream、iostream和string头文件,然后创建ifstream对象打开文件,检查是否成功打开,使用getline逐行读取并输出内容,最后关闭文件。 在C++中打开文本文件进行读取,主要使用标准库中的 fstream 头文件提供的 ifstream 类。下面介绍基本步骤和常见用…

    2025年12月19日
    000
  • 如何在C++中实现一个虚函数_C++虚函数与动态绑定

    在C++中,虚函数通过virtual关键字实现运行时多态,使基类指针能根据对象实际类型调用对应函数。1. 使用virtual声明基类函数以开启动态绑定;2. 派生类重写该函数时可使用override关键字确保正确覆盖;3. 虚函数机制依赖vtable(虚函数表)和vptr(虚函数表指针),每个含虚函…

    2025年12月19日
    000
  • C++模板函数与宏定义结合使用方法

    模板函数与宏结合可提升代码复用性,前者支持类型安全,后者用于文本替换;通过宏生成模板调用或条件编译,如CALL_FOR_TYPE和LOG_CALL,能简化重复代码并实现灵活配置;需避免命名冲突,建议加前缀并及时#undef;优先使用现代C++特性替代宏,确保代码可读性与安全性。 在C++中,模板函数…

    2025年12月19日
    000
  • c++中如何判断字符串是否为空_C++ string空字符串判断方法

    最直接的方法是使用empty()函数,语义清晰且高效;也可用length()或size()与0比较,但推荐empty();避免用c_str()与nullptr比较,因空字符串仍返回指向’’的非空指针。 在C++中,判断一个 std::string 是否为空字符串,最直接和推荐…

    2025年12月19日
    000
  • c++中如何使用explicit关键字_explicit关键字防止隐式转换

    explicit关键字用于防止类构造函数的隐式类型转换,避免因单参数或带默认值参数的构造函数引发意外的隐式转换,提升代码安全性和可读性。 在C++中,explicit关键字用于修饰类的构造函数,防止编译器进行隐式类型转换。如果不使用 explicit ,单参数构造函数可能会被自动调用,从而引发意料之…

    2025年12月19日
    000
  • c++中如何调用C语言函数_extern “C”实现C与C++混合编程

    使用extern “C”可解决C++调用C函数时的链接问题,它关闭名称修饰,确保C与C++函数按C规则链接,实现混合编程。 在C++项目中调用C语言函数时,由于C++支持函数重载,编译器会对函数名进行名称修饰(name mangling),而C编译器不会。这会导致链接阶段找不…

    2025年12月19日
    000
  • c++中如何使用互斥锁mutex_C++多线程同步之互斥锁使用详解

    互斥锁(std::mutex)用于保护共享资源,避免多线程访问导致数据竞争。1. 使用 std::lock_guard 实现RAII管理,自动加解锁;2. 多锁时按序加锁或用 std::lock 避免死锁;3. std::unique_lock 提供更灵活控制,支持延迟加锁与条件变量。合理选择锁类型…

    2025年12月19日
    000
  • C++如何在类成员函数中实现异常安全

    异常安全通过RAII、拷贝交换和事务机制确保对象状态一致;RAII用智能指针管理资源,拷贝交换提供强保证,事务操作确保多步更改的原子性。 异常安全在 C++ 类成员函数中意味着,即使函数抛出异常,对象也能保持有效状态,资源不会泄漏。实现异常安全需要仔细考虑函数可能抛出异常的地方,并采取措施保证状态的…

    2025年12月19日
    000

发表回复

登录后才能评论
关注微信