C++面试问题准备

简介: C++面试问题准备

实际上本人面试多家单位的C++软件工程师岗位,实际问到C++语法问题的很少。现在做纯C++的开发的岗位不多,除了上位机开发,其他基本上是嵌入式开发,做嵌入式别人更加关心的是硬件知识的了解,包括计算机网络、操作系统、ARM开发。


我被问到的问题有这些:

1、设计函数解决平面A、B、C三点共线?

方法一:计算斜率;方法二:计算向量点乘是否等于膜乘积

2、计算机通过什么操作硬件

驱动

3、问了一个局域网中的计算机怎么通信?

路由表

4、怎么对硬件设备开发?

通过开发软件以及相关说明

5、面向对象三大特性?

6、内存泄漏

7、什么时候需要重写析构函数?

8、多线程带来的问题?(被问到两次,比较重要)

饥饿、死锁、活锁

9、设计函数替换String中的"/n"为“ ”


1.static和const区别

static:表示静态变量,存储在内存中的静态区,每次返回上次调用结束时的值,并且在程序结束才会回收内存。

const:表示常量,只读不能修改

static必须在类外初始化。但是static const声明的整型可以在类内声明


2.重写、重载、隐藏

C++的多态是由重写、重载体现的,都是一个接口,重复使用。

重写是指,用virtual修饰基类方法,再用基类指针创建派生类时,调用同名函数会调用到子类的方法

范围:不同类

函数名相同,参数,返回类型都相同


重载分为运算符重载和函数重载

范围:同一个类

函数名相同,返回类型和参数列表必须有一个不同


隐藏是指基类继承派生类时,会隐藏同名属性方法,可以用域作用符调用也可以在积累中用using关键字暴露。


3.new和malloc区别

运算符,函数库

调用构造函数

返回指定类型指针,返回void*指针,需要强制类型转换

new会自动计算需要分配空间,malloc不行

new可以被重载,malloc不能


11.c++内存分区

5大区

栈区

堆区

静态区、全局区

字符串、常量区

代码区


12.指针和引用的区别

指针是一个变量,只不过存储的是一个地址;引用是原变量的别名,传参传引用时可以修改函数本身。


13.STL容器总结

vector:动态分配数组,分配空间-复制元素-释放空间;删除元素时,不会释放空间;删除和插入伴随大量元素移动效率不高;随机访问;历史记录

deque:双端队列;分段数组存储数据;索引数组存储每一段的首地址;两端插入元素效率高;购票系统

list:双向链表,插入删除效率高

关联式容器:有序;平衡二叉树

set/map set无重复 multiset可以有重复 如果需要修改某一个元素值必须先删除原有元素,在插入新的元素(散列表)

单位pair(键值对)


14.vector、map、multimap、unc_map、unordered_multimap的底层数据结构,以及几种map容器如何选择?

vector是基于数组 查找效率高

map、multimap是基于红黑树 有序,插入删除效率高

nordered_map、unordered_multimap 是基于哈希表查找效率高


15.const和#define区别

define 预处理阶段替换,无类型不检查错误,不分配内存

const 编译阶段确定值,有数据类型,静态存储分配空间


16.悬空指针和野指针

悬空指针,指向对象被释放和回收,但是没有让指针指向NULL

野指针,未初始化指针


17.struct和class的区别

struct默认访问权限是继承,class是private,struct是public;


18.各种数据类型占有字节数

char 1字节

short int 2字节

int、long 4字节

float 4字节

long long 8字节

double 8字节


19.深拷贝和浅拷贝

1.函数传参2.函数返回3.对象初始化

浅拷贝:简单的赋值拷贝

深拷贝:在堆区重新申请空间,进行拷贝操作

场景:如果属性有在堆区开辟的,函数当中有指针,一定要自己提供拷贝构造函数,防止浅拷贝带来的重复释放堆区问题


20.C++类中数据成员初始化顺序

1.基类的静态变量或全局变量

2.派生类的静态变量或全局变量

3.基类的成员变量

4.派生类的成员变量


21.static三个作用

1.延长局部变量声明周期

2.static修饰全局变量时,只能在本文件内访问

3.static修饰一个函数,则这个函数只能在本文件中调用


22.友元

友元的目的就是让一个函数或者类 访问另一个类中私有成员

3种实现方法:全局函数做友元,类做友元,成员函数做友元


23.什么情况下,类的析构函数应该声明为虚函数?为什么?

派生类对象需要释放堆区空间的时候需要虚析构函数,不然基类指针静态绑定基类析构函数,无法调用派生类的析构函数。


24.哪些函数不能成为虚函数?5个

1.普通函数

2.友元函数

3.构造函数

4.内联成员函数

5.静态成员函数


25.内联函数和宏定义的区别

1.宏定义不是函数,内联函数是函数

2.宏定义在预处理阶段,内联函数在编译阶段

3.宏定义没有类型检查,内联函数会进行检查

4.处理方式不同,宏定义是在预编译的时候把所有宏名替换,内联函数则是在编译阶段把所有调用内联函数的地方用内联函数插入,省去函数压栈退栈的开销。。


26.内联函数与普通函数的区别

1.普通函数会去寻址,内联函数则是展开

2.内联函数代码必须简单,如果结构复杂会被当做普通函数使用。


27.溢出、越界、泄露

溢出是指要求分配的空间超出系统给你的,比如int a[100000].解决办法在堆区开辟空间

越界数组越界

泄露,内存泄漏,malloc和new分配的内存没有释放造成


28.vector中v[i]与v.at(i)的区别

正常使用无区别,检查越界用at。


29.函数指针

存放函数地址,指向函数的指针。类型 (*指针变量名)(参数列表)。

用途:1.把函数当成变量传参。2.引用不在代码段的函数


30.常量指针和指针常量

常量指针:1.可以改变指向地址2.也可以通过原来声明修改值。3.但是不能通过指针解引用的方式修改值。

指针常量:1.本质是常量2.不能改变指向地址,但可以通过原来声明修改值。3.可以通过解引用方式修改值。


31.头文件包含问题和解决办法

假设在某个C++ 头文件 或 源文件 中,包含了A.h和B.h两个头文件:

#include “A.h”

#include “B.h”

事实上,在头文件B.h中也包含了头文件A的引用。

解决办法:1.条件编译,用预编译语句。2.#pragma once


32.构造函数

基类静态、全局变量->基类成员类->静态、全局->成员类->构造自己

相关文章
|
7月前
|
存储 缓存 数据库
C/C++工程师面试题(数据库篇)
C/C++工程师面试题(数据库篇)
122 9
|
7月前
|
存储 算法 C++
C/C++工程师面试题(STL篇)
C/C++工程师面试题(STL篇)
148 6
|
7月前
|
C++
二叉树进阶面试题(精华总结)【C++版本】
二叉树进阶面试题(精华总结)【C++版本】
|
6月前
|
存储 算法 编译器
C++面试题其一
C++文件编译与执行的四个阶段 预处理:处理#include、#define等预处理指令。 编译:将源码翻译为目标代码。 汇编:将目标代码转换为机器指令。 链接:将目标文件和库文件合并生成可执行文件。 STL中的vector的实现,是怎么扩容的? vector通过动态数组实现,当容量不足时,分配更大的内存(通常是原来的两倍),复制旧数据到新内存,并释放旧内存。
90 2
|
6月前
|
存储 程序员 编译器
C++面试题其二
extern "C" 用于告诉编译器按照C语言的链接方式处理代码,通常用于C++代码与C代码混合编程,以防止因名字修饰(name mangling)引起的链接错误。例如: extern "C" { void c_function(); } 通过这些问题的深入理解和解答,能够更好地掌握C++编程的核心概念和实际应用,为面试做好充分的准备。
81 1
|
6月前
|
存储 网络协议 编译器
【干货总结】Linux C/C++面试知识点
Linux C/C++基础与进阶知识点,不仅用于面试,平时开发也用得上!
628 17
|
7月前
|
存储 算法 C语言
从C语言到C++_39(C++笔试面试题)next_permutation刷力扣
从C语言到C++_39(C++笔试面试题)next_permutation刷力扣
71 5
|
7月前
|
存储 编译器 C语言
从C语言到C++_23(多态)抽象类+虚函数表VTBL+多态的面试题(下)
从C语言到C++_23(多态)抽象类+虚函数表VTBL+多态的面试题
70 1
|
7月前
|
存储 编译器 Linux
从C语言到C++_23(多态)抽象类+虚函数表VTBL+多态的面试题(中)
从C语言到C++_23(多态)抽象类+虚函数表VTBL+多态的面试题
72 1
|
6月前
|
安全 算法 C++
C++面试题其三
继续上篇博客的解答,我们将进一步探讨C++中的一些关键概念和常见面试问题。
59 0