设为首页 收藏本站
查看: 196|回复: 0

[经验分享] C++ 面试题常用总结 详解 4(满足c++ 岗位必备,持续更新)

[复制链接]
累计签到:53 天
连续签到:2 天
发表于 2024-12-10 16:58:39 | 显示全部楼层 |阅读模式
来自:碧波

16. const 可以修饰那些内容

变量、指针和引用、函数、类对象或类指针、函数返回值。

17.  class 和 struct 的区别?有了class 为啥仍还保留 struct?

class 和 struct 用来定义 类 和 结构体,主要区别在于默认的访问权限不同(class 默认私有,struct 默认公有)

它们的区别主要体现在 成员默认的访问权限 和 继承方式 上:

在 class 中,默认的成员访问权限是 private,在 struct 中,默认的成员访问权限是 public

当没有显式指定继承方式时,class 默认是 private 继承,而 struct 默认是 public 继承。

虽然 class 和 struct 在语法上有一些细微差别,但其实它们提供了类似的功能。保留 struct 主要是为了提供语法上的灵活性和向后兼容性。

顺便吆喝一下,技术大厂,前后端测试捞人,近三周条件放宽,来看看!>>>https://jsj.top/f/o38ijj

二、标准库

1. 什么是STL?

STL 是 C++ 标准模板库的缩写。它是 C++ 标准库的一部分,提供了一组通用的模板类和函数,实现了常用的数据结构和算法,以及一些函数对象和迭代器概念,使得 C++ 程序员可以更加高效地进行编程。

容器

如 vector(动态数组)、deque(双端队列)、list(双向链表)、set(集合)、map(映射)等,这些容器提供了高效的数据存储和访问方式,各自适用于不同的需求和使用场景。

算法

如排序、搜索、合并等,这些算法独立于任何特定的容器类型,可以利用这些算法直接对容器进行操作。

迭代器

提供了一种统一的方式来遍历容器中的元素。

函数对象

即重载了函数调用操作符 () 的对象。比如比较、排序等。

适配器

用于修改容器的接口或行为,使其能够满足特定的需求。

2. 数组和vector的区别?
大小:数组的大小在创建时是固定的,而vector的大小是动态可变的。

内存分配:数组的内存分配在栈上(静态数组)或堆上(动态数组),而vector的内存总是动态分配的,通常在堆上。

功能:vector提供了许多内置的操作,如动态扩展、插入和删除等,而数组只能直接访问元素,不支持动态调整大小。

性能:vector在需要扩展时可能会重新分配内存,而数组的内存分配则不会改变。

3.  list 和 vector 的主要区别是什么?
存储方式: list 是一个双向链表,而 vector 是一个动态数组。

访问时间: list 不支持常数时间的随机访问,vector 支持常数时间的随机访问。

插入和删除: 在 list 中,在任意位置插入或删除元素。而在 vector 中,不太适合在中间插入或删除元素。

4. 在什么情况下使用 list 而不是 vector?
当你需要在容器的中间频繁插入和删除元素,而不是在末尾插入或删除时,list 更适合。

当你不需要随机访问元素,而是需要频繁进行插入和删除操作时,list 是更好的选择,因为它的这些操作在常数时间内完成。

5.  set 的底层数据结构是什么?
set 通常使用红黑树或其他自平衡的二叉搜索树实现。它确保所有元素是唯一的,并且保持排序状态,因此插入、删除和查找操作的时间复杂度是对数时间 (O(log n))。


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-1005651-1-1.html 上篇帖子: C++ 面试题常用总结 详解 3(满足c++ 岗位必备,持续更新) 下篇帖子: C++ 面试题常用总结 详解 5(满足c++ 岗位必备,持续更新)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表