c++后台开发八股文遗漏复习点

2024-04-28 04:52

本文主要是介绍c++后台开发八股文遗漏复习点,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

c++ primer

  • cht2

常量指针(pointer to constant)与指针常量(constant pointer)。记:常量指针是指向常量的指针。
可以用常量指针指向非常量对象。但是不建议。
不能用非常量引用指向一个常量对象。可以用常量引用指向一个非常量对象。

typedef char* pstring;
const pstring cstr = 0; // 注意:pstring 是一个指向 char 的常量指针。不能采用直接替换的方式将其理解为 const char* cstr = 0,这是错误的。

auto 会忽略引用与顶层 const。

decltype
如果 decltype 使用的表达式是一个变量,则它返回该变量的类型(包括顶层 const 和引用在内)。
如果 decltype 使用的表达式不是一个变量,则 decltype 返回表达式结果对应的类型。可以使用这种方式来保证不获取引用类型。
注意解引用指针的结果是一个引用类型。给变量加括号的结果也是引用类型。赋值操作的结果也是引用类型。

头文件
头文件通常定义那些只能被定义一次的实体,比如类、const、constexpr 等。
头文件一旦改变,相关的源文件必须重新编译以获取更新过的声明。

预处理变量
预处理变量无视作用域的规则,作用范围是文件内
确保头文件多次包含仍能安全工作的常用技术是预处理器。

  • cht3

cctype 头文件中的 isalnum(), isalpha(), isdigit(), isupper(), islowwer(), ispunct(), isspace(), tolower(), toupper() 等类型
区分 int *ptrs[10]; int (*ptrs)[10]; int (&ptrs)[10] 的不同含义

注意:使用范围 for 循环处理多维数组时,除了最内层的循环外,其他所有循环的控制变量都应该是引用类型。
因为如果不声明为引用类型,编译器会自动将控制变量转换为指向数组首元素的指针,就不能在内层继续使用范围 for 循环处理该控制变量了。

push_back 接受一个参数,该参数是要添加到容器尾部的元素的副本。
emplace_back 接受可变数量的参数,这些参数用来在容器尾部就地构造一个新元素。

// push_back
std::vector<T,Allocator>::push_back
void push_back( const T& value );
constexpr void push_back( const T& value );
void push_back( T&& value );
constexpr void push_back( T&& value );// emplace_back
std::vector<T,Allocator>::emplace_back
template< class... Args >
void emplace_back( Args&&... args );template< class... Args >
reference emplace_back( Args&&... args );template< class... Args >
constexpr reference emplace_back( Args&&... args );

cht4
四种显示类型转换是什么:static_cast\dynamic_cast\reinterpret_cast\const_cast( https://blog.csdn.net/Bob__yuan/article/details/88044361 )
static_cast(expression):

用于执行静态类型转换,在编译时确定,通常用于转换非多态类型(如基本数据类型之间的转换)。
可以用于向上转型、向下转型、非多态类型转换以及显式调用单参数构造函数的转换。
在执行转换时,不会进行运行时类型检查,因此可能导致类型不安全的操作。
const_cast(expression):

用于移除对象的 const 或 volatile 限定符,通常用于在需要时取消对象的常量性。
只能用于转换指针或引用,并且不能用于修改对象的常量性,如果试图这样做将会导致未定义行为。
dynamic_cast(expression):

用于执行动态类型转换,在运行时进行类型检查,通常用于处理多态类型。
只能用于转换指向多态类对象的指针或引用,如果转换失败,返回 nullptr(对于指针)或引发 std::bad_cast 异常(对于引用)。
用于安全地执行向下转型(子类到基类)和跨继承层次的转换。
reinterpret_cast(expression):

用于执行低级别的类型转换,通常用于将指针或整数类型转换为其他指针或整数类型。
在转换过程中不进行类型检查,因此非常危险,可能导致未定义行为。
主要用于与底层系统交互或进行强制类型转换,应谨慎使用。

cht6
用实参初始化形参时会忽略掉顶层 const
函数重载无法区分顶层 const 形参和非顶层 const 形参,但是可以区分底层 const 形参与普通形参

内联函数和constexpr函数:
把内联函数和constexpr函数的定义放到头文件里。
constexpr 函数被隐式地指定为内联函数
constexpr 函数的返回类型及所有的形参类型都必须是字面值类型,函数体中必须有且只有一条 return 语句。
内联函数和 constexpr 函数可以多次定义,但是多个定义必须完全一致。

cht7
用mutable声明的变量,const成员函数也能修改
如何在类中定义内联函数。定义在类内部的函数是隐式的inline函数
什么是转换构造函数
explicit 的用法
友元声明只能出现在类的内部,但是具体位置不限,不是类的成员,不受public、private 限制。

c++静态成员函数为什么不能声明为 const ?
在C++中,静态成员函数是属于类而不是类的实例的。因此,const 关键字在静态成员函数中没有意义。const 关键字用于声明成员函数不修改对象的状态,
但是静态成员函数没有this 指针,因此无法通过它来修改对象的状态。
因此,在静态成员函数中声明 const 是没有意义的,也是不允许的。如果尝试在静态成员函数中使用 const 关键字,编译器会报错。

cht9
基本的顺序容器适配器有 3 种,分别是什么?默认底层容器分别是什么?
queue, priority_queue, stack ,queue 和 stack 的底层容器是 deque,priority_queue 的底层容器是 vector
stack 可以构造于 vector, list, deque 之上。
queue 可以构造于 list, deque 之上。
priority_queue 可以构造于 vector、deque 之上。

可以向容器添加元素的三类函数分别是什么,分别可以用于哪种情况?
push, emplace, insert 三类:
push:包括 push_back(), push_front() 两种,单纯的 push() 操作只用于三种顺序容器适配器,一次只能添加一个元素
emplace:包括 emplace(), emplace_back(), emplace_front() 三种,用参数来构造元素,一次只能添加一个元素
insert:包括 insert() 一种,传入一个迭代器指明位置,再迭代器前插入,可以添加单个元素、多个相同元素、某迭代器范围内的所有元素,花括号列表

删除元素的三类操作分别是什么?用于哪种情况?
pop 类:包括 pop_front(), pop_back() 两种,都返回 void 。单纯的 pop 操作只用于顺序容器适配器。
erase 类:包括 erase() 一种,接受迭代器做参数,可以删除一个元素或一个迭代器范围。返回删除元素之后的元素的迭代器
clear:清空整个容器。不能用于适配器。

这篇关于c++后台开发八股文遗漏复习点的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/942365

相关文章

从入门到精通C++11 <chrono> 库特性

《从入门到精通C++11<chrono>库特性》chrono库是C++11中一个非常强大和实用的库,它为时间处理提供了丰富的功能和类型安全的接口,通过本文的介绍,我们了解了chrono库的基本概念... 目录一、引言1.1 为什么需要<chrono>库1.2<chrono>库的基本概念二、时间段(Durat

C++20管道运算符的实现示例

《C++20管道运算符的实现示例》本文简要介绍C++20管道运算符的使用与实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录标准库的管道运算符使用自己实现类似的管道运算符我们不打算介绍太多,因为它实际属于c++20最为重要的

Visual Studio 2022 编译C++20代码的图文步骤

《VisualStudio2022编译C++20代码的图文步骤》在VisualStudio中启用C++20import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标... 默认创建Visual Studio桌面控制台项目代码包含C++20的import方法。右键项目的属性:

c++中的set容器介绍及操作大全

《c++中的set容器介绍及操作大全》:本文主要介绍c++中的set容器介绍及操作大全,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录​​一、核心特性​​️ ​​二、基本操作​​​​1. 初始化与赋值​​​​2. 增删查操作​​​​3. 遍历方

解析C++11 static_assert及与Boost库的关联从入门到精通

《解析C++11static_assert及与Boost库的关联从入门到精通》static_assert是C++中强大的编译时验证工具,它能够在编译阶段拦截不符合预期的类型或值,增强代码的健壮性,通... 目录一、背景知识:传统断言方法的局限性1.1 assert宏1.2 #error指令1.3 第三方解决

C++11委托构造函数和继承构造函数的实现

《C++11委托构造函数和继承构造函数的实现》C++引入了委托构造函数和继承构造函数这两个重要的特性,本文主要介绍了C++11委托构造函数和继承构造函数的实现,具有一定的参考价值,感兴趣的可以了解一下... 目录引言一、委托构造函数1.1 委托构造函数的定义与作用1.2 委托构造函数的语法1.3 委托构造函

C++11作用域枚举(Scoped Enums)的实现示例

《C++11作用域枚举(ScopedEnums)的实现示例》枚举类型是一种非常实用的工具,C++11标准引入了作用域枚举,也称为强类型枚举,本文主要介绍了C++11作用域枚举(ScopedEnums... 目录一、引言二、传统枚举类型的局限性2.1 命名空间污染2.2 整型提升问题2.3 类型转换问题三、C

C++链表的虚拟头节点实现细节及注意事项

《C++链表的虚拟头节点实现细节及注意事项》虚拟头节点是链表操作中极为实用的设计技巧,它通过在链表真实头部前添加一个特殊节点,有效简化边界条件处理,:本文主要介绍C++链表的虚拟头节点实现细节及注... 目录C++链表虚拟头节点(Dummy Head)一、虚拟头节点的本质与核心作用1. 定义2. 核心价值二

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

C++ 检测文件大小和文件传输的方法示例详解

《C++检测文件大小和文件传输的方法示例详解》文章介绍了在C/C++中获取文件大小的三种方法,推荐使用stat()函数,并详细说明了如何设计一次性发送压缩包的结构体及传输流程,包含CRC校验和自动解... 目录检测文件的大小✅ 方法一:使用 stat() 函数(推荐)✅ 用法示例:✅ 方法二:使用 fsee