c++面试常考的知识点汇总

1. 链表和顺序表的优缺点,在什么场合下适合顺序表,什么场合下适合用链表。

1)顺序表存储原理:顺序表存储是将数据元素放到一块连续的内存存储空间,存取效率高,速度快。但是不可以动态增加长度优点:存取速度高效,通过下标来直接存储,访问速度快,通过下标访问缺点:a.插入和删除比较慢,b.不可以增长长度    比如:插入或者删除一个元素时,整个表需要遍历或移动元素来重新排一次顺序
2)链表存储原理:链表存储是在程序运行过程中动态的分配空间,只要存储器还有空间,就不会发生存储溢出问题优点:插入和删除速度快,保留原有的物理顺序,比如:插入或者删除一个元素时,只需要改变指针指向即可缺点:查找速度慢,因为查找时,需要循环链表访问
3)应用场景:频繁的查找却很少的插入和删除操作可以用顺序表存储,如果频繁的插入和删除操作很少的查询就可以使用链表存储

2、什么是缺省参数?

定义所谓缺省参数,顾名思义,就是在声明函数的某个参数的时候为之指定一个默认值,在调用该函数的时候如果采用该默认值,你就无须指定该参数。缺
省参数使用主要规则:调用时你只能从最后一个参数开始进行省略,换句话说,如果你要省略一个参数,你必须省略它后面所有的参数,即:带缺省值的参数必须放在参数表的最后面。 缺省值必须是常量。显然,这限制了缺省参数的数据类型,例如动态数组和界面类型的缺省参数值只能是 nil;至于记录类型,则根本不能用作缺省参数。 缺省参数必须通过值参或常参传递。声明是带有缺省参数的函数,则缺省值只能写在声明当中。1). 如果函数已经带有缺省参数的函数原型声明,则在该函数的定义中不允许出现缺省值。
2). 一旦为函数的某个参数指定了缺省值,则必须为后续参数也定义缺省值,从右到左定义缺省参数。void showmessage(char *text,int length=1,int color ) ; //错color也应定义缺省值。
3). 调用函数时,如果略去一个参数传递,则略去后续所有参数传递,调用时将参数从左至右,逐一传递给行参。showmessage("hello");showmessage("hello",5);showmessage("hello",5,8);showmessage("hello", ,8);          // 错误

5、什么是引用? 引用有什么作用? 引用和指针有什么区别?
6、什么是函数重载,函数重载底层是怎么实现的? C语言中为什么不能支持函数重载?extern “C” 是什么意思?
7、列出常见的函数调用约定?
8、什么命名空间?它有什么用?

9、什么是结构体?结构体是如何进行内存对齐的? 结构体有什么作用?
10、C++中类和结构体有什么区别? C语言中结构体和C++中结构体有什么区别?
11、写一个函数:获取结构体中某个成员相对于结构体起始位置的偏移
12、什么是类?如何定义一个类?C++有几种访问限定符? C++的三大特性?什么是封装?
13、C++有几种作用域?分别是什么?
14、空类的大小是多少?为什么?

15、什么是this指针?this指针具有什么特性?C++是如何将成员函数和对象绑定在一起的?
16、什么是构造函数?构造函数的作用?构造函数有什么特性?在什么时候调用的?什么是缺省的构造函数?编译器在什么情况下会合成缺省缺省的构造函数?假如类中已经定义了构造函数? 编译器还会在合成吗?
17、什么是初始化列表?类中的数据成员是怎么来初始化的?那些数据成员必须要在类的初始化列表中初始化?为什么?
18、explicit关键字是什么意思?
19、什么是拷贝构造函数?拷贝构造函数是在什么时候调用的?为什么拷贝构造函数的参数必须是引用?如果不是引用,会造成什么后果?
20、什么是析构函数,析构函数有什么特性?在什么时候掉用的?
21、什么是运算符重载?运算符重载有什么特性?那些运算符不能重载?如何重载=和<<、>>运算符?运算符重载时要注意什么?[]、–>、前置++和后置++重载
22、什么是友元,友元有什么特性? 友元的优缺点?
23、什么是类的静态成员?静态数据成员会不会计算在对象的大小中?它有什么特性?静态成员函数中可以调用非静态成员函数吗?非静态成员函数中可以调用静态成员函数吗? 为什么?
24、C/C++中的const有什么区别? const修饰类的成员函数时又什么作用?可以修饰类的构造函数吗? 可以修饰普通的全局函数吗? const对象可以调用非const的成员函数和const成员函数吗?非const对象可以调用const成员函数和非const成员函数吗?const成员函数可以调用非const和const成员函数吗?非const成员函数可以调用const和非const成员函数吗? 为什么?
25、什么是内敛函数?内敛函数有什么优缺点?内敛函数和宏函数有什么区别?既然宏有缺陷为什么C++中没有将宏去掉呢?

26、说说C语言内存管理方式,C++内存管理方式,malloc/realloc/calloc之间的区别?Malloc/free和new/delete new[]/delete[] 之间的区别?

27、什么是操作符new,new 操作符和定位表达式? 定位表达式一般是怎么用的?
28、什么是深拷贝浅拷贝? 给出String类普通版/简洁版/引用计数版三种不同处理方式
29、什么是继承? private、protected和public三种继承方式之间的区别? 什么是赋值兼容规则?什么是Is-a,什么是has-a? 继承体系中构造函数和析构函数的调用顺序?友元和静态成员是否可以继承? 理解单继承、多继承、菱形继承、菱形虚拟继承的对象模型

30、什么是多态? 多态的实现原理? 什么是虚表,虚表使用来干什么的? 多态调用时怎么来实现的?什么是动态绑定和静态绑定?多态有什么优缺点? 什么是重载、覆盖,重写?掌握带有虚函数的单继承、多继承、菱形继承以及菱形虚拟继承的对象模型,什么是纯虚函数?什么是抽象类?
31、什么是泛型编程,函数模板的概念、实例化,模板的参数推演,模板参数列表,函数模板的重载,实例化;类模板,类模板的实例化,特化以及类型萃取? 什么是模板的分离编译?

32、auto_ptr、scoped_ptr、shared_ptr的区别?什么是智能指针的循环引用? 为什么要定制删除器,如何定制?
33、写出C++中的四种类型转化

34、什么是异常,异常的剖出和捕获,异常捕获的匹配规则,异常规范

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/459285.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

aimesh node重启_ASSIMP的数据结构

数据结构是对文件的描述&#xff0c;也是我们想要获取的最终产物&#xff0c;一般来说我们会用这个结果映射到我们自己的模型里面去(这样做是为了降低对这个项目的依赖&#xff0c;如果你的模型都用别人的&#xff0c;还搞毛啊)1.aiScene &#xff1a;根节点struct aiScene{uns…

WCF 初识(一)

WCF的前世今生 在.NETFramework 2.0以及前版本中&#xff0c;微软发展了Web Service&#xff08;SOAP with HTTP communication&#xff09;&#xff0c;.NET Remoting&#xff08;TCP/HTTP/Pipeline communication&#xff09;以及基础的Winsock等通信支持。 由于各个通信方法…

iOS 点转成字符串,再字符串转换成点

CGPointFromString(<#NSString *string#>) NSStringFromCGPoint(<#CGPoint point#>)转载于:https://www.cnblogs.com/56ik/p/5111848.html

C/C++关键字解析

2、C/C分别有多少个关键字&#xff1f; 假如别人问某一个关键字是否属于C/C&#xff0c;要能正确的答出来。 1&#xff09;由ANSI标准定义的C语言关键字共32个 auto double int struct break else long switch case enum register typedef char extern return union const flo…

webpack打开项目命令_webpack打包好的页面在项目中怎么运行?

使用webpack打包好了页面和相关的js文件&#xff0c;然后命令输入webpack-dev-server&#xff0c;再浏览器中输入&#xff1a;http://localhost:9090/WebRoot...打开页面能正常的加载样式和数据&#xff0c;无报错。但是本项目是使用Jfnal框架(不知道有没有关系),然后在eclipse…

常见HTTP状态值

状态代码有三位数字组成&#xff0c;第一个数字定义了响应的类别&#xff0c;且有五种可能取值&#xff1a;1xx&#xff1a;指示信息--表示请求已接收&#xff0c;继续处理2xx&#xff1a;成功--表示请求已被成功接收、理解、接受3xx&#xff1a;重定向--要完成请求必须进行更进…

Linux系统:软链接与硬链接的原理分析

1、相关概念 1、索引节点inode(index node)&#xff1a;inode就是索引节点&#xff0c;它用来存放档案及目录的基本信息&#xff0c;包含时间、档名、使用者及群组等。 inode 是 UNIX/Linux 操作系统中的一种数据结构&#xff0c;其本质是结构体它包含了与文件系统中各个文件相…

python编写命令行框架_python的pytest框架之命令行参数详解(上)

前言pytest是一款强大的python自动化测试工具&#xff0c;可以胜任各种类型或者级别的软件测试工作。pytest提供了丰富的功能&#xff0c;包括assert重写&#xff0c;第三方插件&#xff0c;以及其他测试工具无法比拟的fixture模型。pytest是一个软件测试框架&#xff0c;是一款…

Android学习笔记——Handler(二)

对比请看http://blog.sina.com.cn/s/blog_78c913e30100uqmf.html 以下代码是MainActivity.java中的代码 package com.example.handlertest;import android.app.Activity; import android.os.Bundle; import android.os.Handler;public class MainActivity extends Activity {pr…

纯后台生成highcharts图片有哪些方法?

比如说&#xff0c;领导抛给你一个需求&#xff0c;把一些数据做成图表&#xff0c;每天通过邮件发送&#xff0c;让领导能在邮件中就看到图片&#xff0c;你会有什么思路呢&#xff1f;本人使用的是phantomjs这个神器&#xff0c;它的内核是WebKit引擎&#xff0c;不提供图形界…

操作系统:虚拟页式存储管理(缺页中断、页面置换算法)

1、基本工作原理 1、基本工作原理 在进程开始运行之前&#xff0c;不是全部装入页面&#xff0c;而是装入一个或者零个页面&#xff0c;之后根据进程运行的需要&#xff0c;动态装入其他页面&#xff1b;当内存已满&#xff0c;而又需要装入 新的页面时&#xff0c;则根据某种…

小程序 长按api_高质量的微信小程序样式模板应该长什么样?

现在不懂技术的小白若想快速制作自己的小程序&#xff0c;一般是通过小程序模板来实现。通过在模板上添加自己的图片、文字、商品等等&#xff0c;可以很简单地生成一个小程序。不过要想把小程序做得好看&#xff0c;你得找高质量的小程序样式模板才行。那么高质量的微信小程序…

(笔记)Mysql命令drop database:删除数据库

drop命令用于删除数据库。drop命令格式&#xff1a;drop database <数据库名>;例如&#xff0c;删除名为 xhkdb的数据库&#xff1a;mysql> drop database xhkdb;[例子1] 删除一个已经确定存在的数据库&#xff1a; mysql> drop database drop_database; Query…

web安全测试-AppScan使用分享

这里主要分享如何使用AppScan对一大项目的部分功能进行安全扫描。 ------------------------------------------------------------------------ 其实&#xff0c;对于安全方面的测试知道的甚少。因为那公司每个月要求对产品进行安全扫描。掌握了一人点使用技巧&#xff0c;所…

面试题:找两个有序数组所有数第K小的数

给定两个有序数组arr1和arr2&#xff0c;再给定一个整数k,返回两个数组中所有数中第k小的数。要求&#xff1a;如果arr1的长度为N&#xff0c;arr2的长度为M&#xff0c;时间复杂度请达到O(log(min{M, N}) ) 例如&#xff1a; arr1 {1,2,3,4,5} arr2 {3,4,5} k 1; 因为1为所…

ros 开源物体检测_ROS kinetic + Realsens D435i + ORK + LINEMOD 物体识别

1. ORKORK (Object Recognition Kitchen) 是 ROS 集成的物体识别库&#xff0c;当前 Kinetic 版本的 ROS 只集成了部分功能包的二进制安装文件&#xff0c;所以需通过源码编译安装。安装依赖库sudo apt-get installmeshlabsudo apt-get install libosmesa6-devsudo apt-get ins…

雪碧图sprity 合并多图使用心得

介绍 sprity 是一个模块化的雪碧图生成工具会根据目录中的图片生成相应的雪碧图和样式文件&#xff0c;支持retina图&#xff0c;可以内嵌base64 编码格式的图&#xff0c;支持不同的图片格式和有不同的图片引擎可以选择。sprity 的前身是css-sprite,sprity的 git地址 sprity的…

团队项目第二次冲刺(4)

已经做到两个界面的链接。 今天对用到的数据进行定义及对程序进行完善。 遇到的问题&#xff1a;在进行页面之间的连接时用到的intent语句运用不好。出现了很多次的bug。转载于:https://www.cnblogs.com/cuipengbo/p/4586519.html

itil v4和v3的区别_ITIL从v3到v4 - 这是新的ITIL

ITIL 4即将发布(原计划2019年1月到3月)&#xff0c;v4的领域要大得多&#xff0c;重点放在业务和技术领域&#xff0c;比如我们要如何运作&#xff0c;以及如何通过敏捷&#xff0c;DevOps和数字化转型在未来发挥作用?十年前&#xff0c;比特币推出&#xff0c;詹姆斯卡梅隆发…

面试题:根据Unix时间戳计算时间

根据Unix时间戳计算时间&#xff0c;不分年月大小&#xff0c;每月三十天&#xff0c;每年按360天计算。开始时间1970/01/01 00:00:00,输入秒数&#xff0c;显示时间 思路一&#xff1a;进位&#xff0c;60秒进1分钟&#xff0c;60分进1小时&#xff0c;24小时进1天&#xff0…