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

C++面试---小米

一、static 关键字的作用,及和const的区别
static关键字作用:
1、在类的成员变量前使用,表示该变量属于类本身,而不是任何类的实例。
2、在类的成员函数前使用,表示该函数不需要对象实例即可调用,且只能访问类的静态成员变量和其他静态成员函数。
3、在局部变量前使用,表示该变量在函数调用结束后不会被销毁,而是保持其值不变。
4、在全局变量或函数前使用,限制其作用范围仅在定义的文件内,对其他文件不可见。

static和const区别:
1、static关键字用来定义静态变量,其生命周期为程序执行期间,但它的作用域限定于定义它的文件或函数内。
2、const关键字定义常量,其值在定义后不能被修改,用来保证数据的不变性。它只影响它所修饰的变量的可变性,而不影响其生命周期。

二、extern 关键字的作用
主要作用是:
1、允许在多个文件中访问同一个全局变量或函数。
2、表明变量或函数的定义存在于其他文件中。

三、指针和引用的区别

1、指针是一个变量,其值为另一个变量的地址,通过地址,可以直接访问和修改对应内存中的值。
2、引用是别名,它为对象提供了一个新的名字,对引用的操作等同于对对象本身的操作。
3、指针可以为空,引用必须绑定到一个对象。
4、指针的值(即所指对象的地址)可以改变,但引用一旦与某个对象绑定,就不能再改变引用到其他对象。

四、c++内存分配的方式

1、静态存储:编译时分配,如全局变量、静态变量。
2、自动存储:函数内部声明的变量,如局部变量,随着函数调用创建和退出销毁。
3、动态存储:使用new和delete进行手动分配和释放的堆内存。

五、静态内存分配和动态内存分配的区别,静态分配的优缺点

区别:
1、静态内存分配在编译时就确定了存储空间的大小和生命周期,通常用于全局变量和静态局部变量。
2、动态内存分配在运行时根据需要动态地分配和释放内存,通常使用new和delete操作符。

静态内存分配的优点:
1、管理简单,没有额外的运行时开销。
2、生命周期长,随程序启动创建,程序结束时销毁。

静态内存分配的缺点:
1、灵活性低,必须提前预知并定义所需内存大小。
2、可能会导致内存浪费,若预分配内存未被充分利用

六、讲一下c++智能指针及shared_ptr的底层实现
unique_ptr:独占所有权,不支持复制和赋值操作。
shared_ptr:引用计数机制,多个智能指针可以共享同一个对象。
weak_ptr:不对对象的所有权计数,用于解决shared_ptr的循环引用问题。

shared_ptr的底层实现
包括两个主要部分:
1、控制块:存储引用计数和指向动态分配的对象的指针。
2、智能指针对象:包含对控制块的引用。

七、map 和 unordered_map 区别
map:
1、基于红黑树实现。
2、元素按键自动排序。
3、查找、插入和删除操作的时间复杂度为O(log n)。

unordered_map:
1、基于哈希表实现。
2、元素不排序,按哈希值存储。
3、平均情况下查找、插入和删除操作的时间复杂度为O(1),最坏情况为O(n)。

八、STL有哪些容器,各自特点

序列容器:
1、vector:动态数组,支持快速随机访问。
2、list:双向链表,支持快速插入和删除。
3、deque:双端队列,两端都可以快速插入和删除。

关联容器:
1、set:集合,元素唯一且自动排序。
2、map:键值对集合,键唯一且自动排序。
3、multiset:集合,元素可以重复,自动排序。
4、multimap:键值对集合,键可以重复,自动排序。

无序关联容器(C++11新增):
1、unordered_set:集合,元素唯一,基于哈希表实现,不排序。
2、unordered_map:键值对集合,键唯一,基于哈希表实现,不排序。
3、unordered_multiset:集合,元素可以重复,基于哈希表实现,不排序。
4、unordered_multimap:键值对集合,键可以重复,基于哈希表实现,不排序。

适配器容器:
1、stack:栈,后进先出。
2、queue:队列,先进先出。
3、priority_queue:优先队列,元素按优先级出队。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 食源送系统项目的测试
  • 服务重启脚本
  • 从实现第一个ArkTs应用开始入门
  • C#中ToString()在windows和linux的差异
  • MySQLl的存储引擎
  • 二进制部署k8s集群之CoreDNS部署及多master节点负载均衡以及高可用(下)
  • django网络爬虫系统- 计算机毕业设计源码81040
  • 前端进阶|详细讲讲函数柯里化
  • mybatis多条件in查询拓展
  • 运维之路----计算机基础
  • Kafka动态授权认证:利用SASL/SCRAM机制提升安全性
  • Nginx代理路径被吃
  • 如何在Python中使用网页抓取API获得Google搜索结果
  • 我们的网站被狗爬了!
  • C语言之unsigned long long与指针相互转换实例(五十五)
  • 网络传输文件的问题
  • 《Javascript数据结构和算法》笔记-「字典和散列表」
  • 【Redis学习笔记】2018-06-28 redis命令源码学习1
  • java多线程
  • Less 日常用法
  • MyEclipse 8.0 GA 搭建 Struts2 + Spring2 + Hibernate3 (测试)
  • SpiderData 2019年2月25日 DApp数据排行榜
  • Synchronized 关键字使用、底层原理、JDK1.6 之后的底层优化以及 和ReenTrantLock 的对比...
  • Vue组件定义
  • 动手做个聊天室,前端工程师百无聊赖的人生
  • 发布国内首个无服务器容器服务,运维效率从未如此高效
  • 探索 JS 中的模块化
  • 无服务器化是企业 IT 架构的未来吗?
  • 异步
  • const的用法,特别是用在函数前面与后面的区别
  • 阿里云服务器如何修改远程端口?
  • 不要一棍子打翻所有黑盒模型,其实可以让它们发挥作用 ...
  • 基于django的视频点播网站开发-step3-注册登录功能 ...
  • ​DB-Engines 12月数据库排名: PostgreSQL有望获得「2020年度数据库」荣誉?
  • ​决定德拉瓦州地区版图的关键历史事件
  • (02)vite环境变量配置
  • (arch)linux 转换文件编码格式
  • (C++二叉树05) 合并二叉树 二叉搜索树中的搜索 验证二叉搜索树
  • (Matalb分类预测)GA-BP遗传算法优化BP神经网络的多维分类预测
  • (十)【Jmeter】线程(Threads(Users))之jp@gc - Stepping Thread Group (deprecated)
  • (未解决)macOS matplotlib 中文是方框
  • (转)关于如何学好游戏3D引擎编程的一些经验
  • ./configure,make,make install的作用
  • .NET / MSBuild 扩展编译时什么时候用 BeforeTargets / AfterTargets 什么时候用 DependsOnTargets?
  • .NET Compact Framework 3.5 支持 WCF 的子集
  • .NET Compact Framework 多线程环境下的UI异步刷新
  • .Net Core webapi RestFul 统一接口数据返回格式
  • .net core 控制台应用程序读取配置文件app.config
  • .NET Remoting学习笔记(三)信道
  • .NET 直连SAP HANA数据库
  • .NET/C# 异常处理:写一个空的 try 块代码,而把重要代码写到 finally 中(Constrained Execution Regions)
  • .NET_WebForm_layui控件使用及与webform联合使用
  • .NET程序员迈向卓越的必由之路
  • /proc/stat文件详解(翻译)
  • @CacheInvalidate(name = “xxx“, key = “#results.![a+b]“,multi = true)是什么意思