C++易混淆概念

时间:2023-06-22 13:20:26

1. 引用和指针有什么区别?

本质:一个是别名,一个是地址
1. 指针可以在运行时改变其所指向的,引用一旦和某个对象绑定就不再改变
2. 引用没有const, 指针有const
3. 从内存上看,指针会分配内存区域,引用不会,它仅仅是一个别名
4. 在参数传递时,引用会做类型检查,而指针不会 
5. 引用不能为,指针可以为空

【类型检查、const、内存、值、空】

2. const和define有什么区别?

本质define只是字符串替换,const参与编译运行
1. define不会做类型检查,const拥有类型,会执行相应的类型检查 
2. define仅仅是宏替换,不占用内存,而const会占用内存 
3. const内存效率更高,编译器通常将const变量保存在符号表中,而不会分配存储空间,这使得它成为一个编译期间的常量,没有存储和读取的操作

3. define和inline有什么区别?

本质define只是字符串替换,inline由编译器控制
• define只是简单的宏替换,通常会产生二义性;而inline会真正地编译到代码中 
• inline函数是否展开由编译器决定,有时候当函数太大时,编译器可能选择不展开相应的函数

4. malloc和new有什么区别?(malloc/free和new/delete)

本质:malloc/free 是C语言的库函数,new/delete是C++的操作符

malloc仅仅用来分配内存,而不会执行相应的构造函数,函数返回值void*;而new会调用相应的构造函数返回值的是相应对象类型的指针

(new内部是调用malloc的,new相当于malloc和构造函数的一个结合体。)

follow up:有了malloc/free为什么还要new/delete?

对于非内部数据类型的对象而言,光用malloc/free无法满足动态对象的要求。对象在创建的同时要自动执行构造函数,对象在消亡之前自动执行析构函数。由于malloc/free是库函数而不是运算符,不在编译器的控制范围之内,不能把执行构造函数和析构函数的任务强加于malloc/free.

5. C++中static关键字作用有哪些?

1. 扩展生存周期(如局部static变量)
2. 限制作用域:用于全局变量。与普通全局变量不同的是,它表明该变量的作用域仅限于当前cpp文件,因此当其他cpp文件中同样出现同名的static变量时,他们是不同的独立的变量。

follow up:

1) 成员函数能否同时修饰为static和const的呢?

不能。

static成员函数:由类的所有对象共有,以为单位。

const函数:表示不会修改对象的成员变量。是以对象为单位。

static函数是从类的角度,const函数是从对象的角度。一个函数要么是的,要么是对象的,不可能同时满足。

(以上都是针对成员函数来说。成员变量的话是可以同时用的。)

2) static函数能否调用非static函数呢?

不能。类似上一题。

static是以类为单位,非static修改的对象的成员变量。它们不是一个层次的。

6. C++中const关键字作用有哪些?

1.) 修饰变量

指向const变量的指针:(const在*左边。指针所指的内容不能被修改)
  const int* ptr;
  int const* ptr;
const指针:(const在*右边。指针本身不能被修改)
  int* const ptr;

2.) 修饰成员函数,表示该成员函数不会修改成员变量

7. const变量真的不能被修改吗?

可以通过指针修改。如,

const int a = ;
int* ptr = NULL;
ptr = (int*)(&a);
*ptr = ;

详见NCH slide。

8. C++中包含哪几种强制类型转换?他们有什么区别和联系?

dynamic_cast : 
继承体系安全向下转型或跨系转型;找出某对象占用内存的起始点
static_cast:
同旧式C转型,如int 到double
const_cast:
常用于去除某个对象的常量性
reinterpret_cast
不具备移植性,常见用途是转化函数指针类型

Use dynamic_cast for converting pointers/references within an inheritance hierarchy.

Use static_cast for ordinary type conversions.

Use reinterpret_cast for low-level reinterpreting of bit patterns. Use with extreme caution.

Use const_cast for casting away const/volatile. Avoid this unless you are stuck using a const-incorrect API.

ref     ref2

9.

STL共有六大组件
  1、容器。2、算法。3、迭代器。4、仿函数。6、适配器。

仿函数(functor),就是使一个的使用看上去象一个函数。其实现就是类中实现一个operator()。【本质是一个

reference

10. 面向对象的特性:封装、继承、多态

ref

11.  重载、覆盖和隐藏的区别

首先,重载、覆盖和隐藏都是针对两个同名函数而言的。

重载必须是同一个类中的两个同名函数,参数不同

覆盖和隐藏都是针对的派生类和基类而言。

如果派生类的函数与基类的函数同名,但是参数不同,此时,不论是否是虚函数,基类的该函数将被隐藏

如果派生类的函数与基类的函数同名,并且参数相同,如果基类的该函数不是虚函数,则基类的该函数被隐藏;如果基类的该函数虚函数,则基类的该函数被覆盖。(覆盖只针对虚函数而言)

调用时:

重载:看参数。

覆盖:看指针实际指向的对象(即虚函数调用规则)。

隐藏:看指针类型

ref: http://www.cnblogs.com/txwsh1/archive/2008/06/28/1231751.html 【总结的很全面。从上到下把例子都看看就明白了】