1. 在C++中,不能被重载的运算符有:

  • sizeof
  • . 成员运算符
  • .* 成员指针运算符
  • :: 作用域运算符
  • ?: 条件运算符

2. C++语言多态性:编译时多态和运行时多态:

  • 编译时多态可通过函数重载和模板实现;
  • 运行时多态可通过虚函数实现;
  • 实现运行时多态机制称为动态绑定;

3. C++中,头文件引用问题:

  • #include <> 编译器只搜索系统目录,不会搜索本地目录。比如你自己写一个头文件,你用#include <>会出错。
  • #inlude " " 首先搜索本地目录,如果本地目录没有才会搜索系统目录;
  • 可以把系统的文件 放到当前目录下 改成 ""   可以优先使用;

4. 设a、b、c、d、m、n均为int型变量,且a=5、b=6、c=7、d=8、m=2、n=2,则逻辑表达式(m=a>b)&&(n=c>d)运算后,n的值为?

解析:此题考查运算符优先级和&&使用规则,首先=优先级低于判断< ,有m=0,&&左侧为false,则不执行右侧,因此n的值不变为2;

5. 重载函数是指同一个函数名可以对应多个函数的实现,编译器会根据参数个数、参数类型不同而自动调用相应的函数;注意函数返回值类型不能作为重载的判断条件。

6. 运算符重载规则:

  • 友元函数重载运算符时,因为没有this指针指向对象,因此参数个数保持和原来一样,参数列表为1,说明是1元,为2说明是2元;若无参,说明重载出错;
  • 成员函数重载时,参数列表为空,是一元,参数列表是1,为2元;

7. 循环语句问题:

  • while(条件)为false时,循环体不执行;
  • do while(),循环体至少执行一次;
  • continue只能出现在for/while/do while循环内部,或嵌套在此类循环里的语句和块内部,不能在单独的switch中用continue;
  • break用于终止离它最近的循环语句;

8. 构造函数问题:

  • 无论是默认构造函数还是拷贝构造函数,均无返回值;
  • 拷贝构造函数的参数可以使一个或多个,但左起第一个必须是类的引用对象;
  • 若类定义中没有声明拷贝构造函数,则编译器会自动生成一个缺省的拷贝构造函数,但是不会是该类的保护成员;
  • 通过拷贝函数可以将另一个对象作为对象的初值;

9. const与define:

  • const常量有数据类型,而宏常量没有数据类型。编译器可以对const进行类型安全检查,但是对define只进行字符替换,没有类型安全检查,并且在字符替换中可能会产生意料不到的错误(边际效应);
  • 有些集成化的调试工具可以对const进行调试而不能对define进行调试。
  • 在C++程序中只使用const常量而不使用define常量,即const常量完全取代define常量。

10. 在类的const成员函数中,用mutable修饰成员变量后,就可以修改类的成员变量了~

11. 关于类型转换:

  • dynamic_cast:继承体系安全向下转型或跨系转型;找出某对象占用内存的起始点;
  • static_cast:同旧式C转型,如int到double,(显式类型转换);
  • const_cast:去除对象常量性;
  • reinterpret_cast:本质依赖于机器,为运算对象的位模式提供较低层次上的重新解释,不常用,较危险~

C++基础知识易错点总结(1)的更多相关文章

  1. js基础知识易错点(一)

    最近替另一个项目招人,要求基础知识好,随便问了一些基础题,发现了一些易错的点,总结一下. 1.判断一个空数组 var arr = []; 1)JSON.stringify(arr) == " ...

  2. C++基础知识易错点总结(2)

    1. 若一组待排数据有序,花费时间最多的是:快速排序,T(n)=O(n^2): 2. 有 1000 个无序的整数,希望使用最快的方式找出前 50 个最大的,最佳的选择是? 快速排序:在最理想的情况下, ...

  3. JavaGuide易错点总结

    基础知识易错点 1. object.equals("str") 容易报空指针异常,应使用"str".equals(object); 还可以使用JDK7引入的工具 ...

  4. 细节!重点!易错点!--面试java基础篇(二)

    今天来给大家分享一下java的重点易错点第二部分,也是各位同学面试需要准备的,欢迎大家交流指正. 1.字符串创建与存储机制:当创建一个字符串时,首先会在常量池中查找是否已经有相同的字符串被定义,其判断 ...

  5. 细节!重点!易错点!--面试java基础篇(一)

    今天来给大家分享一下java的重点易错点部分,也是各位同学面试需要准备的,欢迎大家交流指正. 1.java中的main方法是静态方法,即方法中的代码是存储在静态存储区的. 2.任何静态代码块都会在ma ...

  6. python易错知识集合

    本篇用于记录在写leetcode时遇到的python易错知识. 2019.8.29 1.Python range() 函数用法: range(start, stop[, step]) start: 计 ...

  7. [SQL] SQL 基础知识梳理(三) - 聚合和排序

    SQL 基础知识梳理(三) - 聚合和排序 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5926689.html 序 这是<SQL 基础知识梳理 ...

  8. Java基础知识二次学习--第三章 面向对象

    第三章 面向对象   时间:2017年4月24日17:51:37~2017年4月25日13:52:34 章节:03章_01节 03章_02节 视频长度:30:11 + 21:44 内容:面向对象设计思 ...

  9. 【RL-TCPnet网络教程】第2章 嵌入式网络协议栈基础知识

    第2章        嵌入式网络协议栈基础知识 本章教程为大家介绍嵌入式网络协议栈基础知识,本章先让大家有一个全面的认识,后面章节中会为大家逐一讲解用到的协议. 基础知识整理自百度百科,wiki百科等 ...

随机推荐

  1. Django Web补充

    一.今日内容 一.Django ORM连表操作 Q,F 二.Form表单验证 面向对象 正则 三.Session框架 面向对象 cookie toanado扩展 二.Django ORM一对多数据创建 ...

  2. prolog 规则

    规则 规则由几个互相依赖的简单句(谓词)组成.用来描述事实之间的依赖关系,如:因果关系,蕴含关系,对应关系 规则的实质就是存储起来得查询 其语法结构如下: head:-body head 为谓词的定义 ...

  3. callback转Promise

    环境:  nodejs - v6.2.0 const fs = require('fs'); let Promise = require('bluebird'); let readSync = fun ...

  4. MongoDB-JAVA-Driver 3.2版本常用代码全整理(4) - 地理空间索引

    MongoDB的3.x版本Java驱动相对2.x做了全新的设计,类库和使用方法上有很大区别.例如用Document替换BasicDBObject.通过Builders类构建Bson替代直接输入$命令等 ...

  5. 初学c# -- 学习笔记(七) RichTextBox支持GIF

    园子里许明吉博客写的一篇,刚好用到这个,写的非常好.转过来了 不过在应用中也有一些问题,win10下不能中文输入,凑合着进行了修改, 下面是原来的代码: private void button2_Cl ...

  6. 【Python全栈笔记】08 [模块二] 20 Oct 递归 -*** 待补充

    递归 引入 递归的表现形式 下面是四个函数,互相调用返回结果 # 引入 递归的表现形式 def f1(): ' def f2(): r = f1() return r def f3(): r = f2 ...

  7. JSP(include指令与<jsp:include>动作的区别)

    <%@ page language= "java" contentType="text/html;charset=UTF-8" %><html ...

  8. NPOI MVC 模型导出Excel通用类

    通用类: public enum DataTypeEnum { Int = , Float = , Double = , String = , DateTime = , Date = } public ...

  9. 驱动开发学习笔记. 0.04 linux 2.6 platform device register 平台设备注册 1/2 共2篇

    驱动开发读书笔记. 0.04  linux 2.6 platform device register 平台设备注册  1/2 共2篇下面这段摘自 linux源码里面的文档 : Documentatio ...

  10. 【POJ2482】Stars in Your Window(线段树,扫描线)

    题意:在二维坐标系中有一些带权值的点,要求用一个长宽指定不能互换的框套住其中的一些,使得它们的权值和最大. n<=10000 x,y<=2^31 思路:首先按X排序,将Y坐标离散化,X坐标 ...