• C++ 初始化列表


    C++中提供了初始化列表对成员变量进行初始化。

      语法规则:class_name::class_name()

              m1(v1),m2(v2,v3),m3(v3)

            {

              .......

            }

    注意:

      成员的初始化顺序,与成员的声明顺序相同。

      成员的初始化顺序与初始化列表的位置无关。

      初始化列表比构造函数先执行。

    测试代码:  

    #include <stdio.h>
    
    class val
    {
        private:
        int i;
        public:    
        val(int val)
        {    
            i = val;
            printf("i = %d
    ",i);
        }
    };
    class Test
    {
        private:
            const int Ci=10;
            val m1;
            val m2;
        public:
            Test():m2(2),m1(1)
            {
                //Ci = 1;
                printf("Test::Test()
    ");
            }
            int get_Ci()
        {
            return Ci;
        }
    };
    
    
    int main(int argc, char *argv[])
    {
        Test Ci;
        printf("Ci = %d
    ",Ci.get_Ci());
        return 0;
    }

      运行结果:  

    i = 1
    i = 2
    Test::Test()
    Ci = 10

    类中的const成员

      类中个const成员变量会被分配空间,(所分配空间的位置取决于对象在哪个位置被声明。)

      类中的const 成员的实质是一个只读变量,可以通过指针修改其值。

      类中个const 可以使用初始化列表指定初始值,也可以在定义的时候进行初始化。、

      注意:编译器无法得到const成员的初始值,因此在类中声明的const 只读变量无法进入符号表成为一个真正意义上的常量。

    测试代码:

      

    #include <stdio.h>
    
    class val
    {
        private:
        int i;
        public:    
        val(int val)
        {    
            i = val;
            printf("i = %d
    ",i);
        }
    };
    class Test
    {
        private:
            const int Ci;
            val m1;
            val m2;
        public:
            Test():m2(2),m1(1),Ci(100)
            {
                //Ci = 1;
                printf("Test::Test()
    ");
            }
            int get_Ci()
        {
            return Ci;
        }
        void change_Ci(int CI)
        {
            int *p = const_cast<int *>(&Ci);//delete only read
            *p = CI;
        }
    };
    
    
    int main(int argc, char *argv[])
    {
        Test Ci;
        printf("Ci = %d
    ",Ci.get_Ci());
        Ci.change_Ci(1000);
        printf("Ci = %d
    ",Ci.get_Ci());
        return 0;
    }

      上面代码通过 const_cast<Type *>(&val);关键字去掉了Ci的只读属性。

      然后通过*p = CI; 修改Ci的值

    运行结果:

      

    i = 1
    i = 2
    Test::Test()
    Ci = 100
    Ci = 1000
  • 相关阅读:
    解决Linux中Too many open files问题
    10个必需的iOS开发工具和资源
    @ModelAttribute跟@SessionAttributes的应用
    7个改变世界的Java项目
    Java序列化与反序列化
    微软推出“IE9梦幻任务栏Pin计划”
    java中replace和replaceAll的区别
    【转】hibernate中annotation方式SchemaExport无法生成表的原因(ORA02261)
    permgen space报错
    em和px
  • 原文地址:https://www.cnblogs.com/hjxzjp/p/11660894.html
Copyright © 2020-2023  润新知