C++知识点总结(纯C++!!)
1.重载函数是否能够通过函数返回值的类型不同来区分?
不可以。因为在C++编程中,函数的返回值可以忽略(不使用其返回值),程序中调用此时函数名相同和参数相同的两个函数对编译器和程序员来说是没有办法区分的,编译器会提示出错。
2.C++多态机制的实现
(1)重载:同一个类中同一个函数的不同实现,必须保证函数参数不同(类型,个数,顺序),本质上与多态无关。使用重载函数,编译器会根据函数的名称和参数定义来生成函数的内部标识符,保证每个函数的标识符是唯一的,这样在链接时就可以链接到对应的函数。重载属于静态绑定,在编译过程中就能确定调用哪一个函数,是早期绑定,与多态原理不同。
(2)覆盖:也称为重写,子类中对父类的同名函数同参数的重写,父类的函数必须设置为虚函数,这样保证使用基类指针或者引用指向不同的子类对象可以动态调用属于具体子类的方法而不是调用基类的方法,从而实现多态。
PS:C++中 多态一般默认是指动态多态(通过类继承机制和虚函数机制实现),是在运行时确定的,在面向对象编程中直接被称为多态,而静态多态一般是指使用函数重载或者模板机制实现的。模板也允许将不同的特殊行为和单个泛化记号相关联,由于这种关联处理于编译期而非运行期,因此被称为“静态”。可以用来实现类型安全、运行高效的同质对象集合操作。C++ 的STL库大量使用了模板机制来实现,而并没有使用虚函数机制,属于静态多态。
详情可以参考以下博客:https://blog.csdn.net/sinat_20265495/article/details/50112311
3.队列和栈的共同点以及不同点(C++版本)
队列:这里只说单向队列,就是我们平常所说的FIFO队列,它满足先进先出的规则,即只能在队尾插入元素,提取元素只能在队头。(C++里面提供了queue容器作为单向队列的实现)
栈:栈满足LIFO规则(后进先出),插入和取出操作只能在栈顶进行(C++提供了stack容器作为栈的实现)
相同点:都是线性表结构,并且只能在端点进行数据的插入和读取(受限制的线性表结构),都不能进行随机存取,都不支持遍历(不开临时空间),在C++ stl中可以采用deque作为两者的底层容器;
不同点:栈和队列的操作不同,栈只能在线性表的一端进行插入和删除,而队列则是只能在表的一端进行插入,在另一端进行删除;栈符合LIFO原则,而队列符合FIFO原则,即满足队列的操作原则;
具体可以参考这篇博客:https://blog.csdn.net/zqixiao_09/article/details/51474589
4.模板(函数模板、类模板)
可以参考这篇博客:https://blog.csdn.net/sinat_20265495/article/details/50112311
5.C++内存模型(内存布局)
一般来说,一个C++程序所分配的内存空间主要分为五个部分:堆、栈、静态存储区、代码段
根据C++中类的情况,可以分为以下几种情况进行讨论:
单一类:
(1)空类:占据一个字节,用于标识这个类是一个空类,没有实际含义,使用sizeof操作符可以看到大小为1个字节。
(2)只有成员变量的类:该类的大小为所有普通成员变量所占据的内存大小的和(静态成员变量并不存放在对象的内存空间中),内存布局如下图所示,可以看出在内存中是按照变量声明的顺序存放的。
(3)只有虚函数的类:根据虚函数的实现机制,该类的对象所占据的内存只有一个虚函数表指针(vfptr),指向一个虚函数表,该表按照函数的声明顺序存储着虚函数的函数指针。内存布局如下所示:
从上面我们可以看到,在该类的对象中,只存放一个虚函数表指针,它指向虚函数表,虚函数表并没有存放在对象的内存空间中。该类的对象的大小为虚函数表指针大大小(64位系统为8个字节,32位系统则为4个字节)
(4)既有虚函数,又有成员变量的类
这样的类的对象内存中既有虚函数表指针,又有成员变量(按照声明的顺序存放),内存布局如下图所示: https://blog.csdn.net/it_yuan/article/details/24651347
单继承、多继承的情况则比较复杂,此处不进行详细分析,具体可以自己网上找一下或者参考以下这篇博客: https://blog.csdn.net/it_yuan/article/details/24651347
6.函数调用压栈出栈过程及参数入栈顺序
函数对应的栈其实是栈帧,由系统从系统栈(内存中的栈空间)划分一定大小的空间给函数,函数独占该栈帧,栈帧里面存放着该函数执行时的局部变量 、上一个栈帧的ESP和EBP、函数调用的返回地址(函数的后面的指令的地址),在函数调用过程中涉及了栈帧的分配、切换和释放,不同操作系统、不同语言、不同编译器的实现机制基本相同,但是具体的实现细节有所不同,例如参数压栈出栈的顺序等。具体可以参考以下博客(个人觉得两位大神的分析特别详细):
https://blog.csdn.net/u011555996/article/details/70211315
https://www.cnblogs.com/roy-blog/p/6367093.html
7.C++ inline原理(注意与define的区别和联系)
inline是C++的一种机制,作用于函数,将一个函数声明为inline,可以让编译器在编译代码时,将“对此函数的每一个调用”都以函数本体替换之,该过程发生在编译期间。inline的优点是:它可以省去函数调用所带来的额外开销,提高程序的速度。缺点也很明显:首先,过分使用inline函数会导致代码膨胀,占用过多内存和硬盘空间;其次,在升级inline函数时,需要所有引用它的模块都要重新编译。
综合以上说明,inline一般用于函数体比较小,频繁切换的函数上面。另外需要强调的一点是,千万不要将构造或析构函数inline。原因是,这种函数往往看起来是空的,而实际上在编译期间会生成很多代码,如果将它们inline了,很容易就会导致代码膨胀。
8.define和const的区别
const是定义了一种数据类型,被其修饰的变量会被系统分配内存空间,存放在静态存储区,在编译时会进行类型检查,而define定义的常量本质上是一种宏替换,不是一种数据类型,系统不会为其分配内存空间,宏定义的常量在预处理的时候会被替换,不会进行类型检查。
具体差异可以参考这篇博客:https://blog.csdn.net/yingyujianmo/article/details/51206460
9.虚继承和虚基类表、虚基类表指针
虚继承是为了解决多重继承中派生类对象内存同时存在多份虚基类的实体而提出的,当使用虚继承时,派生类中最多保存一份虚基类的实体,但是需要在内存中增加虚基类表指针。具体可以参考 以下博客:
https://blog.csdn.net/bxw1992/article/details/77726390
10.C++ 11多线程 thread库
C++11标准中新增了对多线程的标准库支持,使多线程程序的开发更加方便,主要是通过thread类来创建、调度、运行线程,并提供了大量多线程操作的API,可以说是服务器端开发的一大神器,具体可以参考这篇博客,讲得很详细,这里就不再赘述。
https://www.cnblogs.com/wangguchangqing/p/6134635.html#autoid-3-0-0
C++知识点总结(纯C++!!)的更多相关文章
- 前端小知识点---html换行被解析为空格的相关知识
这个系列主要记录一下常被忽略但又经常产生影响的知识点,纯做个记录,方便查询 html换行被解析为空格也是常说的3像素空隙的问题,根据测试不同浏览器产生的空隙大小会不一样,Chrome,Firefox, ...
- Java程序员的日常——经验贴(纯干货)
工作当中遇到的事情比较杂,因此涉及的知识点也很多.这里暂且记录一下,今天遇到的知识点,纯干货~ 关于文件的解压和压缩 如果你的系统不支持tar -z命令 如果是古老的Unix系统,可能并不认识tar ...
- 全网最牛X的!!! MySQL两阶段提交串讲
目录 一.吹个牛 二.事务及它的特性 三.简单看下两阶段提交的流程 四.两阶段写日志用意? 五.加餐:sync_binlog = 1 问题 六.如何判断binlog和redolog是否达成了一致 七. ...
- 【干货分享】前端面试知识点锦集01(HTML篇)——附答案
一.HTML部分 1.浏览器页面有哪三层构成,分别是什么,作用是什么? 构成:结构层.表示层.行为层分别是:HTML.CSS.JavaScript作用:HTML实现页面结构,CSS完成页面的表现与风格 ...
- CSS3知识点整理&&一些demo
css3能做什么 响应式开发的基础,然后能实现一些酷炫的效果咯. 以下案例纯css3实现,一点都没用js (入门简单,但是水很深) 叮当猫纯用css3做出 http://codepen ...
- Java进击C#——语法之知识点的改进
本章简言 上一章我们讲到关于面向对象思想上C#和JAVA之差别.笔者分别从面向对象的三大特性入手.而本章主要讲一些C#改进的知识点.在.NET Framework 2.0之后出现很多新的知识点.这些知 ...
- 纯css3艺术文字样式效果代码
效果:http://hovertree.com/texiao/css3/1/ 本效果主要使用text-shadow实现.参考:http://hovertree.com/h/bjaf/css3_text ...
- 【转】HTML5的小知识点小集合
html5的小知识点小集合 html5知识 1. Doctype作用?标准模式与兼容模式各有什么区别? (1).<!DOCTYPE>声明位于位于HTML文档中的第一行,处于<h ...
- IT技术学习指导之Linux系统入门的4个阶段(纯干货带图)
IT技术学习指导之Linux系统入门的4个阶段(纯干货带图) 全世界60%的人都在使用Linux.几乎没有人没有受到Linux系统的"恩惠",我们享受的大量服务(包括网页服务.聊天 ...
随机推荐
- 用script标签加载
此文已由作者杨帆授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 注:经过更深入的测试,实在不好意思,这篇文章是有问题的 更改script的type属性 并不能通过src来加载 ...
- 详解Redis Cluster集群
Redis Cluster是Redis的分布式解决方案,在Redis 3.0版本正式推出的,有效解决了Redis分布式方面的需求.当遇到单机内存.并发.流量等瓶颈时,可以采用Cluster架构达到负载 ...
- 51单片机 小车 L298N pwm调速 串口控制 按键控制
难点:1.串口定时器T1,和T0定时器优先级 2.pwm频率与占空比的设置 按键控制 按键1——前进 按键2——后退 按键3——加速 按键4——减速 (板子上只有四个按键) 串口控制 ‘1’——前进 ...
- P5161 WD与数列(后缀自动机+线段树合并)
传送门 没想出来→_→ 首先不难看出要差分之后计算不相交也不相邻的相等子串对数,于是差分之后建SAM,在parent树上用线段树合并维护endpos集合,然后用启发式合并维护一个节点对另一个节点的贡献 ...
- bzoj4145 [AMPPZ2014]The Prices(状压dp)
Description 你要购买m种物品各一件,一共有n家商店,你到第i家商店的路费为d[i],在第i家商店购买第j种物品的费用为c[i][j], 求最小总费用. Input 第一行包含两个正整数n, ...
- IT兄弟连 JavaWeb教程 Servlet会话跟踪 Cookie技术简介
Cookie的英文原意是“点心”,它是在客户端访问Web服务器时,服务器在客户端硬盘上存放的信息,好像是服务器送给客户的“点心”.服务器可以根据Cookie来跟踪客户状态,这对于需要区别客户的场合(如 ...
- poj3417 闇の連鎖 【树上差分】By cellur925
闇の連鎖(yam.pas/c/cpp)题目描述传说中的暗之连锁被人们称为 Dark.Dark 是人类内心的黑暗的产物,古今中外的勇者们都试图打倒它.经过研究,你发现 Dark 呈现无向图的结构,图中有 ...
- 1-6static关键字
static的作用? static可以修饰变量,被static修饰的变量叫做静态变量,程序运行时静态变量存放在方法区里面,因此,静态变量在类加载阶段赋值,并且只赋值一次.请看例1 static可以修饰 ...
- Unity3D中GameObject 详细介绍
通过Hierarchy面板下的Create菜单可以手动地创建一个GameObject,它可以是一个相机,一个灯光,或者一个简单的模型,当我们要在程序里面动态地创建一个相机的时候,可以new一个Game ...
- P1984 [SDOI2008]烧水问题
题目描述 把总质量为1kg的水分装在n个杯子里,每杯水的质量均为(1/n)kg,初始温度均为0℃.现需要把每一杯水都烧开.我们可以对任意一杯水进行加热.把一杯水的温度升高t℃所需的能量为(4200*t ...