笔试强训选择题day11,12

day11

内联函数

笔试强训选择题day11,12_第1张图片
内联函数不能太长,有循环,有递归

重载函数

笔试强训选择题day11,12_第2张图片
函数名一样,参数列表不一样

构造函数次数

笔试强训选择题day11,12_第3张图片
数组看数组中有几个元素,指针数组只需要构造一次

笔试强训选择题day11,12_第4张图片
ad是一个数组指针,该指针指向PAT类型的3个连续的空间,该类型并未创建对象,所以没有调用构造函数

赋值运算符重载

笔试强训选择题day11,12_第5张图片
如果用户没有显式定义赋值运算符重载时,编译器自动生成一份,按照浅拷贝方式来实现

赋值运算符只能作为类的成员函数重载,参数列表中有一个隐藏的this指针,所以只能放一个参数

静态成员函数

笔试强训选择题day11,12_第6张图片
静态成员时是所有类对象共享的,所以不能在类内初始化

笔试强训选择题day11,12_第7张图片
静态成员变量没被const修饰,只能在类中声明,类外定义
加了const就可以类内定义

可以通过对象.静态成员变量或者类名::来访问

析构函数

笔试强训选择题day11,12_第8张图片
笔试强训选择题day11,12_第9张图片
笔试强训选择题day11,12_第10张图片

笔试强训选择题day11,12_第11张图片
delete将当前对象销毁掉
不推荐该使用方法

模板调用

笔试强训选择题day11,12_第12张图片
笔试强训选择题day11,12_第13张图片

day12

引用和指针

笔试强训选择题day11,12_第14张图片
引用:是一个别名,与其引用的实体共用一端内存空间,编译器不会给引用变量重新开辟新的内存空间

析构函数

笔试强训选择题day11,12_第15张图片
A:析构函数类中类外都能定义,可以类中声明,类外定义
析构函数没参数,没返回值

运算符重载

笔试强训选择题day11,12_第16张图片
类名,关键字,运算符一个都不能少

构造函数个数

笔试强训选择题day11,12_第17张图片
创建一个对象才会调用构造函数,创建一个指针不会调用
new开辟空间后,调用构造函数初始化
引用只是一个别名,没创建对象

类和对象描述

笔试强训选择题day11,12_第18张图片
类使用来描述对象,描述对象有哪些属性,有哪些方法
对象是类的具体体现
笔试强训选择题day11,12_第19张图片
单例模式:一个对象只能创建一个对象。
但可以创建多个对象
笔试强训选择题day11,12_第20张图片
A选项:如果没定义的话,编译器会生成一个无参的构造函数,有的话就不会生成
B选项:有的类可以不用生成拷贝构造,先在本类声明但不定义,编译器也不会自己生成。
D选项:只能由一个析构函数

析构函数和this指针

笔试强训选择题day11,12_第21张图片
笔试强训选择题day11,12_第22张图片
笔试强训选择题day11,12_第23张图片
类中每个非静态成员函数中都有一个隐藏的this 指针参数

友元函数不是类的成员函数,也没有this指针,也不会收访问限定符的限制

堆和栈

笔试强训选择题day11,12_第24张图片
堆上都是动态分配,而栈上既可以动态分配,也可以静态分配—比如在函数体中创建了一个数组

笔试强训选择题day11,12_第25张图片
alloca是在栈上开辟的,自动释放

你可能感兴趣的:(c++,数据结构,算法)