• C++进阶小结


    1.C++中类的不同存储区的对象的初始值

    class test;

     1 class test
     2 {
     3 private:
     4     int i;
     5     int j;
     6 public:
     7     int geti()
     8     {
     9         return i;
    10     }
    11     int getj()
    12     {
    13         return j;
    14     }
    15 };

    1.在上创建对象时,成员变量初始值为随机值

    test *p = new test;

    2.在上创建对象时,成员变量初始值为随机值

    test t;

    3.在静态存储区创建对象时,成员变量初始为0

    全部变量:test t;

    静态变量 static test t;

    2.C++类中const问题

    const对象只能调用const成员函数,const成员函数也只能调用const成员函数,类成员中const成员是只读变量,可以通过修改指针指向的值来修改

    3.类中成员函数与对象的关系

    类的每个对象都拥有一套自己的成员变量,但是成员函数仅有一套,所有的对象共用这一套函数,函数被不同对象调用的区别在于类中提供了一个this指针,该指针指向特定的对象

    4.拷贝构造函数中的const 对象为何直接调用成员private变量?

    1 class test
    2 {
    3     int i;
    4 }
    5 
    6 test(const test& t)
    7 {
    8     i=t.i;
    9 }

     我们都知道私有成员是可以通过成员函数来使用,拷贝构造函数是特殊的成员函数,所以可以直接使用privete成员

    5.类中静态变量

    公有静态变量可以被类名对象名直接调用

    私有静态变量能通过对象名调用

    静态变量能在类外初始化,因为静态变量不属于任何一个对象

    6.静态成员函数与普通成员函数的区别

    静态成员函数中没有this指针

    静态成员函数能访问静态成员函数和静态变量(类似于const)

    公有静态成员函数可以通过类名直接调用,也可以通过对象名(不分public和private),普通成员函数只能通过对象名调用,因为需要与对应的this指针相匹配

    7.函数重载

    函数名和函数参数是用来确定函数的,仅靠函数名不可以,且重载函数必须在同一作用域

    静态函数可以和普通函数构成重载(同一作用域)

    类中也可以重载函数(构造函数)

    相同的参数,不同的顺序也发生重载

    1 double fun(int i,double j)
    2 {
    3     
    4 }
    5 
    6 double fun(double j,int i)
    7 {
    8     
    9 }

    函数返回值不能做重载依据

    形参中存在const不能重载

    double fun(const int i,double j);
    
    double fun(int i,double j);

    8 汇编代码与源代码

    现代编译器会自动进行优化,导致源码的二进制代码被优化后无法区别,如前置++和后置++ ,所有无法从汇编代码获取程序源码 

    9 隐式类型转换

    short 和 char 型做运算得到的结果为 int型,而非直观上的short型,因为4字节整型运算更加高效

    10 转换构造函数

    1 class test
    2 {
    3   public:
    4           test(){}
    5     
    6           test(int i){}
    7 }

    如果存在如下代码

    test t;

    t=5;

    此时就会调用test(int i)这个函数(转换构造函数),等价于t=test(5), 类似于将int 类型转换为test类型

    可以在转换构造函数前添加 explicit 关键字来阻止编译器自动隐式转换

    注:转换构造函数只有一个参数,且该参数类型为其他类型(不能是类本身类型)

    11 类型转换函数

    类中的成员函数  operator Type() ,Type 为不同于类类型

    与转换构造函数类似

    调用方式:隐式调用

    12 子类中可以定义父类中的同名成员,但子类成员会隐藏(不等于没有)父类的成员,如果需要调用父类成员变量,需要加上父类的作用域分辨符

    13   构造函数内部是不会发生多态,在构造函数执行时,虚函数表指针未被正确初始化,只会调用当前类中的版本

      析构函数内部也不可能发生多态行为,在析构函数执行时,虚函数表指针已经被摧毁,只会调用当前类中的版本

      构造函数不能成为虚函数,因为虚函数指针未被正确初始化

      析构函数可以发生多态,既可以成为虚函数

    14 函数模板创建过程中会有两个步骤

      1.对模板本身进行编译

      2.对替换后的代码进行编译

    15 类模板特化只是模板的分开实现,本质上还是同一个类模板

    16 重定义是一个类模板和一个新类(或者两个类模板),使用的时候需要考虑如何选择的问题

      特化是以统一的方式使用类模板和特化类,编译器会优先选择特化类

    17 智能指针 #include<memory>

    auto_ptr:一个指针对象只能指向一片地址,且某一片地址只能被一个auto_ptr指针所指向,一旦发生赋值操作,内存所有权就会转换

    share_ptr指针变量可以多个共享一片内存

    unique_ptr与auto_ptr类似,但是不能转换内存所有权

     

    Qt中的智能指针:

    -------QPointer

        优点:可以多个指针指向同一片内存,但是一旦内存被释放,所有的指针全为NULL,

        缺点:析构时不会自动销毁所指向的内存

    -------QSharePointer

        它属于引用计数型指针,只有当引用计数为0时才会销毁对象

    18 关键字 typeid()

      当参数为类型名时,则返回类型名

      当参数为变量时:

        变量类型为普通类型时,则返回静态类型

        变量类型为类类型,且不含虚函数时,则返回静态类型

        变量类型为类类型,且含有虚函数时,则返回动态类型

    19 编译器选择函数顺序

      函数重载->函数模板->变参函数

    PS:持续更新

  • 相关阅读:
    C++类成员变量多用指针不用对象
    C++列表初始化是初始化本类自身含有的成员变量,不能直接初始化继承过来的成员变量
    std::unorder_set你插入元素的顺序不一定就是元素在里面的元素
    yolo3使用darknet卷积神经网络训练pascal voc
    windows下执行tensorflow/models的代码显示No module named 'object_detection'
    extern const 不能一起用
    常见PID里面的像素大小
    ajax 异步请求webservice(XML格式)
    剖析下聊天室
    session更换存储,实现在多台服务器共享
  • 原文地址:https://www.cnblogs.com/cdp1591652208/p/7290872.html
Copyright © 2020-2023  润新知