在类中,如果你不希望某些数据被修改,可以使用const关键字加以限定。const 可以用来修饰成员变量和成员函数。...const成员变量 const 成员变量的用法和普通 const 变量的用法相似,只需要在声明时加上 const 关键字。...初始化 const 成员变量只有一种方法,就是通过构造函数的初始化列表,这点在前面已经讲到了,请猛击《C++初始化列表》回顾。...const成员函数(常成员函数) const 成员函数可以使用类中的所有成员变量,但是不能修改它们的值,这种措施主要还是为了保护数据而设置的。const 成员函数也称为常成员函数。...我们通常将 get 函数设置为常成员函数。读取成员变量的函数的名字通常以get开头,后跟成员变量的名字,所以通常将它们称为 get 函数。
一、静态成员变量概念 1、静态成员变量引入 在 C++ 类中 , 静态成员变量 又称为 静态属性 ; 静态成员归属 : 静态成员变量 是特殊的成员变量 , 是 类所有的 成员 , 而不是对象所有的成员...Student 类的 静态成员 成员变量 初始化有两种方式 : 声明 并 进行初始化 : 声明类内部已经定义的 静态成员变量 , 然后进行初始化 ; // 在类外部初始化静态成员变量 int Student...::number = 1; 只进行初始化 : 只对 类内部已定义的 静态成员变量 进行单纯的赋值 ; // 在函数中为 类 静态成员变量 赋值 Student::number = 2; 4、静态成员变量访问...进程结束时销毁 ; 静态成员变量在多个对象之间共享 , 在 程序生命周期 之内 , 类的多个对象的 静态成员的值 是相同的 ; 二、完整代码示例 下面的代码中 : 定义了 Student 类 , 其中定义了...在类外部声明并初始化静态成员变量 int Student::number = 1; 单独进行 静态成员变量 初始化 , 代码为 Student::number = 2 ; // 在函数中为 类 静态成员变量
结论 在进入构造函数体之前,数据成员的初始化就已完成。 数据成员的初始化顺序取决于声明顺序。...而进入函数体之前的数据成员的初始化如何控制呢?答案就是——成员初始化列表。...这两种方式的差别相当于CA a; a = b;与CA a(b);的差别,很显然使用成员初始化列表效率要更高一点。...special A CB::CB(const char*) pName = special B CA::CA(const CA&) CB::CB(const CB&) CTest::CTest(CA) 可以看出在成员初始化列表中的顺序并无作用...,对成员的初始化还是以声明顺序为依据。
普通类中成员函数一开始就创建 类模板中成员函数在调用时才创建 #include #include using namespace std; //类模板与函数模板的区别...void f2() { cout << "f2函数调用" << endl; } }; template class person3 { public: T1 p; //类模板中的成员函数在调用时才会去创建...(); } void f4() { p.f2(); } }; void t1() { person3 per; //per.f4();//报错,说明函数调用才会去创建成员函数
成员变量初始化有三种方式: 在构造函数体内赋值初始化 在自定义的公有函数体中赋值初始化(一般用于成员变量的初始化) 在构造函数的成员初始化列表初始化 一、构造函数体内初始化 说明:在构造函数体内的初始化方式...,本质是是为成员变量赋值,而不是真正意义上的初始化,这点要特别注意!...=strlen(name); m_name=new char[len+1];//创建内存 strcpy(t m_name,name); } else m_name=nullptr; } } 二、自定义的公有函数体中赋值初始化...特点: 初始化顺序与书写的在构造函数后的顺序无关,而与成员变量的定义顺序有关(下面有演示案例) 初始化列表初始化优先于构造函数内的代码执行顺序 写在构造函数的后面,随着构造函数的执行而执行 初始化顺序...) 一个特殊情况:如果用一个成员变量去初始化另一个成员变量,就要注意初始化顺序了 因此,我们在初始化的时候,尽量避免用某些成员去初始化另一个成员 //下面代码中,i先被初始化,但是i是根据j初始化的,但
成员变量初始化有三种方式: 在构造函数体内赋值初始化 在自定义的公有函数体中赋值初始化(一般用于成员变量的初始化) 在构造函数的成员初始化列表初始化 一、构造函数体内初始化 说明:在构造函数体内的初始化方式...,本质是是为成员变量赋值,而不是真正意义上的初始化,这点要特别注意!...特点: 初始化顺序与书写的在构造函数后的顺序无关,而与成员变量的定义顺序有关(下面有演示案例) 初始化列表初始化优先于构造函数内的代码执行顺序 写在构造函数的后面,随着构造函数的执行而执行 初始化顺序...而与成员变量定义的顺序有关 例如下面的代码,在构造函数花括号后m_height放在m_age前面,但是先初始化m_age再初始化m_height,因为m_age先定义 class Cperson {...) 一个特殊情况:如果用一个成员变量去初始化另一个成员变量,就要注意初始化顺序了 因此,我们在初始化的时候,尽量避免用某些成员去初始化另一个成员 //下面代码中,i先被初始化,但是i是根据j初始化的,但
一、继承中成员变量同名的处理方案 1、继承中成员变量同名的场景说明 子类 继承 父类 的 成员 , 如果 子类 中定义了 与 父类成员变量 同名的 变量 , 子类 仍然 可以 继承 父类的 同名 成员变量...; 子类的成员变量 与 继承自父类成员变量 的 名称 出现相同的情况 , 使用 域作用符 :: 对同名的 成员变量 进行区分 ; 2、使用域作用符区分同名成员变量 子类中使用 域作用符 :: 处理同名成员变量的方案...: 继承自父类的成员变量 , 使用 父类名称::成员变量名称 替代 成员变量名称 , 如 : Parent 是父类名称 variable 是父类中的变量名称 如果子类中也定义了 variable...变量 , 子类中使用该方式 访问 父类中的 variable 变量 ; // Parent 是父类名称 // variable 是父类中的变量名称 // 如果子类中也定义了 variable 变量 ,...子类中使用该方式 访问 父类中的 variable 变量 ; Parent::variable 子类的成员变量名称 , 可以使用 Child::variable 的方式进行访问 , 也就是可以不使用域作用符
一、支持 数组类模板 存储的 自定义类 1、可拷贝和可打印的自定义类 在上一篇博客 中 , 定义了 可拷贝 与 可打印 的 自定义类 Student , 可以被存放到 数组类模板 中 ; 由于其 成员变量..., 开始讨论 自定义类 中是 char* 类型指针的情况 , 这里涉及到了 堆内存分配 以及 深拷贝 问题 ; 如果将上述 Student 类中的 char m_name[32] 数组成员 , 改为 char...* m_name 指针成员 ; 那么需要进行 堆内存管理 , 在 构造函数中 分配堆内存 ; 在 析构函数中 释放堆内存 ; 为了避免 浅拷贝 问题出现 , 需要 进行 等号 = 运算符重载 ; 以及...自动在堆内存中分配内存 , 然后为 堆内存 中的空间赋值 ; Student(){ m_age = 10; // 创建一个数组个数为 1 的数组, 存放 '\0' 值 // 这是一个空字符串...< " , age : " << s.m_age << " ; "; return out; } 6、改进方向 - 重载拷贝构造函数 和 等号运算符 重载拷贝构造函数 和 等号运算符 , 方便类初始化
static成员变量,在编程中我们时常都会遇到,那么你是否对static变量以及static成员函数有一定深入的认识呢?...static定义的成员变量,存储的区域是内存四区(栈区、堆区、全局区、代码区)中的全局区,在程序运行之前就已经生成在全局区中,直到程序运行结束才会被系统释放。...在C++中有时会定义一些static变量,同时也会定义一些static成员函数。...对于static成员函数以及属性的调用需要注意的点有以下几个: 1.static成员函数的调用的成员变量(属性)只能够是static成员属性,不能够调用普通成员变量属性(因为编译器无法确定调用的是哪个对象的成员属性...); 2.static成员变量(属性)并不占用类的内存空间,static成员变量并不存储在类中,存储在全局区; 3.static成员变量(属性)时所有对象共同拥有的一份变量,并不属于任何一个对象成员;
静态数据成员实际上是类域中的全局变量。所以,静态数据成员需要在类外定义(初始化),而不应该被放在类声明中。 原因是类声明中只是描述如果分配内存并不会真正的分配内存,而定义是一定要分配内存的。...静态成员是“类级别”的,也就是它和类的地位等同,而普通成员是“对象(实例)级别”的。类级别的成员,先于该类任何对象的存在而存在,它被该类所有的对象共享。 其定义方式与全局变量相同。...举例如下: xxx.h文件 class base{ private: static const int _i;//声明,标准c++支持有序类型在类体中初始化,但vc6不支持。...}; xxx.cpp文件 const int base::_i=10;//定义(初始化)时不受private和protected访问限制. 注:不要试图在头文件中定义(初始化)静态数据成员。...★这个特性,我不知道是属于标准c++中的特性,还是vc6自己的特性。 静态数据成员的值在const成员函数中可以被合法的改变。
标题:c++中的静态成员static使用注意事项 静态成员变量特点: 1.所有对象共享一份数据 2.在编译阶段分配内存(程序还没运行前就分配内存) 3.类内声明,类外初始化(不初始化,无法使用)...静态成员函数特点 1.所有对象共享同一个函数 2.静态成员函数只能访问静态成员变量 ?
class A:v1 = 100 # 类变量def __init__(self):self.v2 = 200 # 成员变量v3 = 300 # 局部变量类变量可以由类名统一修改:A.v1 = 300#...则每一个A实例里v1都变成300成员变量只能由实例自己改变:A.v2 # 这个是错的。...a = A()a.v2 # 这个是可以访问的。局部变量只在函数内部生效
l诶模板中成员函数和普通类成员函数创建的时机是有区别的: 1.普通的成员函数一开始就可以创建; 2.类模板的成员函数在调用时才创建; #include using namespace...Person2 { public: void showPerson2() { cout << "这里是person2" << endl; } }; //不确定obj的类型...,所以这里是可以编译成功的 template class Person { public: T obj; void show1() { obj.showPerson1
分享一个之前学的知识点,感觉还挺重要的,就是当一个类中的某个数据成员同时拥有就地初始化、构造函数初始化列表和构造函数函数体里的赋值,那么它会先执行哪个?最后生效的又是哪个呢?...根据老师的讲解,数据成员的初始化次序依次为: 就地初始化 > 构造函数的初始化列表 >构造函数里的赋值(严格意义上不能成为初始化) 而当三种初始化方式都有时,构造函的函数体里的赋值肯定执行,并且生效...,但是就地初始化和构造函数初始化列表的执行情况是怎样呢?...所以当一个数据成员同时拥有就地初始化和初始化列表时,它会忽略就地初始化而执行构造函数初始化列表。...如果到代码中的有参构造函数的函数体中加上 this->id = 20; ,运行结果会变为: 0 n = 1,id = 1 n = 1,id = 20 可以看到赋值把初始化列表给id初始化的值覆盖掉了
初始化过程是这样的: 1.首先,初始化父类中的静态成员变量和静态代码块,按照在程序中出现的顺序初始化; 2.然后,初始化子类中的静态成员变量和静态代码块,按照在程序中出现的顺序初始化; 3.其次,...初始化父类的普通成员变量和代码块,在执行父类的构造方法; 4.最后,初始化子类的普通成员变量和代码块,在执行子类的构造方法; 类的加载顺序: 父类静态成员变量、静态块>子类静态成员变量、 静态块>...父类普通成员变量、非静态块>父类构造函数>子类 普通成员变量、非静态块>子类构造函数 静态代码块:随着类的加载而执行,而且只执行一次 非静态代码块:每创建一个对象,就执行一次非静态代码块 关于各个成员简介
类模板中成员函数和普通函数创建时机是有区别的: 普通类中的成员函数一开始就创建; 类模板中的成员函数在调用时才创建。...ob.show_demo2(); } }; void test(){ Test t{}; t.func1(); // t.func2(); 调用时才创建的。
class T2> Person::Person(T1 name, T2 age) { this->name = name; this->age = age; } //对于成员函数...,需要指明类的参数的代表 template void Person::show() { cout name << endl
C++程序的内存格局通常分为四个区: 全局数据区(data area),代码区(code area),栈区(stack area),堆区(heap area)(即自由存储区)。...全局数据区存放全局变量,静态数据和常量; 所有类成员函数和非成员函数代码存放在代码区; 为运行函数而分配的局部变量、函数参数、返回数据、返回地址等存放在栈区;余下的空间都被称为堆区。...根据这个解释,我们可以得知在类的定义时,类成员函数是被放在代码区,而类的静态成员变量在类定义时就已经在全局数据区分配了内存,因而它是属于类的。...对于非静态成员变量,我们是在类的实例化过程中(构造对象)才在栈区或者堆区为其分配内存,是为每个对象生成一个拷贝,所以它是属于对象的。
构造函数初始化列表 总结 : 初始化列表 可以 为 类的 成员变量 提供初始值 ; 初始化列表 可以 调用 类的 成员变量 类型的 构造函数 进行成员变量初始化操作 ; 初始化列表 可以 使用 构造函数...中传入的 参数 ; 类初始化时 , 根据定义顺序 , 先调用 成员变量的 构造函数 , 然后调用外部类构造函数 , 析构函数正好相反 ; 实例对象 的 const 成员变量 必须只能在 初始化列表 中进行...初始化 , 所有的构造函数都要进行初始化操作 ; 一、构造函数 的 初始化列表 中 为 const 成员变量初始化 1、初始化 const 常量成员 如果 类 中定义了 被 const 修饰 的 成员变量..., 那么该成员变量 必须被初始化 , 否则会报错 ; 对象中的 const 成员 必须在 声明后 立刻进行初始化 ; const 成员的初始化 只能通过 构造函数 的 初始化列表 进行初始化 ; 注意...进行赋值 的 , 因此 这里 必须在 构造函数的 初始化列表中 对 const 成员变量 进行赋值 ; 2、错误代码示例 - 没有初始化常量成员 在下面的 类 B 中 , 定义了常量 const int
领取专属 10元无门槛券
手把手带您无忧上云