当前位置: 首页 > news >正文

C++ 6

C++构造函数有几种,分别什么作用

在C++中,构造函数有几种不同的类型,每种都有其特定的作用:

  1. 默认构造函数:没有参数的构造函数,用于创建对象的默认实例。
  2. 参数化构造函数:带参数的构造函数,允许在创建对象时初始化成员变量。
  3. 拷贝构造函数:以同一类的实例为参数的构造函数,用于复制已有对象。
  4. 移动构造函数:以同一类的实例的右值引用为参数,用于利用即将销毁的对象的资源。
  5. 转换构造函数:允许将其他类型或值隐式转换为当前类类型的实例。
  6. 委托构造函数:一个构造函数调用另一个构造函数来完成初始化,可以是同一个类的其他构造函数。
  7. 初始化列表构造函数:使用成员初始化列表来初始化成员变量,这是最高效的初始化方式。
  8. 常量构造函数:声明为const的构造函数,可以用于创建常量对象。
  9. constexpr构造函数:允许在编译时初始化对象,用于定义和初始化字面量类型的对象。
    每种构造函数的使用场景不同,例如:
    ● 默认构造函数用于快速创建对象,而不需要显式提供任何初始化参数。
    ● 参数化构造函数提供了灵活性,允许在创建对象时定制其状态。
    ● 拷贝构造函数和移动构造函数分别用于对象的复制和移动,是实现资源管理的关键。
    ● 转换构造函数和委托构造函数提供了更灵活的对象初始化方式。
    ● 初始化列表构造函数是C++中推荐的成员初始化方式,因为它可以提高效率。

深拷贝与浅拷贝的区别

  1. 浅拷贝
    ● 定义:浅拷贝仅复制对象本身,不复制对象所指向的动态分配的内存。换句话说,它只复制内存中的对象副本,而不复制对象内部指向的任何动态分配的资源。
    ● 实现:通常通过复制构造函数或赋值运算符实现。
    ● 特点:
    ○ 速度快,因为只涉及基本数据类型的复制。
    ○ 如果原始对象包含指针,浅拷贝会导致两个对象尝试管理相同的动态内存,这可能导致多重释放和悬空指针问题。
  2. 深拷贝
    ● 定义:深拷贝不仅复制对象本身,还递归地复制对象所指向的所有动态分配的内存。这意味着每个对象都有自己的独立资源副本。
    ● 实现:通常需要自定义复制构造函数或赋值运算符来确保所有动态分配的资源都被正确复制。
    ● 特点:
    ○ 速度慢,因为需要递归地复制所有资源。
    ○ 可以安全地使用复制出的对象,而不担心资源管理问题。

STL 容器了解哪些

  1. 序列容器
    ● std::vector: 动态数组,提供快速随机访问。
    ● std::deque: 双端队列,提供从两端快速插入和删除的能力。
    ● std::list: 双向链表,提供高效的元素插入和删除。
    ● std::forward_list: 单向链表,每个元素只存储下一个元素的引用。
    ● std::array: 固定大小的数组,具有静态分配的内存。
  2. 关联容器:
    ● std::set: 基于红黑树,存储唯一元素的集合, 会默认按照升序进行排序。
    ● std::multiset: 允许容器中有多个相同的元素。
    ● std::map: 基于红黑树,存储键值对的有序映射。
    ● std::multimap: 允许映射中有多个相同的键。
    ● std::unordered_set: 基于哈希表,提供平均时间复杂度为 O(1) 的查找。
    ● std::unordered_map: 基于哈希表,存储键值对的无序映射。
  3. 容器适配器(Container Adapters):
    ● std::stack: 后进先出(LIFO)的栈。
    ● std::queue: 先进先出(FIFO)的队列。
    ● std::priority_queue: 优先队列,元素按优先级排序。

vector和list的区别

  1. vector
    ● 基于动态数组:std::vector 基于可以动态扩展的数组实现,这意味着它在内存中连续存储元素。
    ● 随机访问:提供快速的随机访问能力,可以通过索引快速访问任何元素。
    ● 内存分配:通常在内存分配上更紧凑,因为元素紧密排列,没有额外的空间用于链接或指针。
    ● 时间复杂度:
    ○ 元素访问:O(1),即常数时间复杂度。
    ○ 插入和删除:在 vector 的末尾是 O(1),但如果需要在中间插入或删除元素,则可能需要 O(n),因为可能需要移动后续所有元素。
    ● 内存管理:使用连续内存分配,可以利用缓存的优势,提高访问速度。
  2. list
    ● 基于双向链表:std::list 是基于双向链表的容器,每个元素通过节点链接到前一个和后一个元素。
    ● 非连续存储:元素在内存中不是连续存储的,每个元素包含指向前一个和后一个元素的指针。
    ● 时间复杂度:
    ○ 元素访问:O(n),需要从头开始遍历到所需位置。
    ○ 插入和删除:非常快速,特别是当需要在列表中间插入或删除元素时,操作是 O(1),前提是已经拥有指向待插入或删除元素的迭代器。
    ● 内存管理:由于元素间通过指针链接,内存分配可能更分散,但插入和删除操作不需要移动其他元素。
  3. 使用场景
    ● std::vector:
    ○ 当你需要快速随机访问元素时。
    ○ 当你需要在末尾快速添加或删除元素时。
    ○ 当你关心内存使用效率时。
    ● std::list:
    ○ 当你需要在列表中间高效地插入或删除元素时。
    ○ 当你不需要随机访问元素时。
    ○ 当你需要一个灵活的容器,可以动态地添加和删除元素而不会引起大量的内存复制或移动。
http://www.lryc.cn/news/529672.html

相关文章:

  • 使用QSqlQueryModel创建交替背景色的表格模型
  • jinfo命令详解
  • 如何在 ACP 中建模复合罐
  • 【Java】微服务找不到问题记录can not find user-service
  • 基于Hutool的Merkle树hash值生成工具
  • Windows系统本地部署deepseek 更改目录
  • 深度学习篇---数据存储类型
  • 可被electron等调用的Qt截图-录屏工具【源码开放】
  • electron 应用开发实践
  • openssl 生成证书 windows导入证书
  • 程序员学英文之At the Airport Customs
  • 字节iOS面试经验分享:HTTP与网络编程
  • 游戏引擎 Unity - Unity 启动(下载 Unity Editor、生成 Unity Personal Edition 许可证)
  • 前端八股CSS:盒模型、CSS权重、+与~选择器、z-index、水平垂直居中、左侧固定,右侧自适应、三栏均分布局
  • Linux网络 | 网络层IP报文解析、认识网段划分与IP地址
  • 服务器虚拟化实战:架构、技术与最佳实践
  • (leetcode 213 打家劫舍ii)
  • [C语言日寄] <stdio.h> 头文件功能介绍
  • 一文读懂 Faiss:开启高维向量高效检索的大门
  • 【二叉搜索树】
  • R语言统计分析——ggplot2绘图5——拟合光滑曲线
  • 疯狂拆单词01
  • 高效学习方法分享
  • 01.双Android容器解决方案
  • 一文大白话讲清楚webpack进阶——9——ModuleFederation实战
  • Mysql意向锁
  • 输入一行字符,分别统计出其中英文字母,空格,数字和其他字符的个数。
  • AD电路仿真
  • vim 中粘贴内容时提示: -- (insert) VISUAL --
  • Redis_Redission的入门案例、多主案例搭建、分布式锁进行加锁、解锁底层源码解析