时间:2021-05-19
类定义时的静态成员只是声明,静态成员的定义和初始化要在类之外完成
C++的static关键字可修饰类成员变量/方法,表示变量/方法不从属于特定对象,而是属于类的。仔细琢磨静态成员变量,会发现其与C++的方式既相容也矛盾,具有特殊性。
先说相容的一面。·C/C++·有声明和定义的说法:声明给出签名,定义给出具体实现。对类型而言,声明不一定能知道其对象占用空间大小,但根据定义肯定能确定内存占用。说静态成员与C++方式是相容的,因为其初始化方式与方法的定义一致。下面是一个例子:
// Foo.hppnamespace tlanyan { // 类声明和定义 class Foo { private: // 声明静态成员 static int value; public: // 方法声明 void increaseValue(); int getValue() const; };}// Foo.cppnamespace tlanyan { // 定义静态成员变量并初始化 int Foo::value = 0; // 类方法定义 void Foo::increaseValue() { ++ value; } int Foo::getValue() { return value; }}相对于相容点,静态成员变量更多展现出怪异的一面,以下是个人总结:
其中第4点比较重要。在不支持C++11的编译器上,要完成静态map成员,就不得不借助函数返回:
#include <map>// 类定义class Foo {private: std::map<const char*, int> maps; ...}// 静态成员初始化std::map<const char*, int> Foo::maps = Foo::initMap();// 或者使用全局函数std::map<const char*, int> Foo::maps = initMap();C++11引入了统一初始化和lambda表达式,初始化的写法更为简单:
// 统一初始化std::map<const char*, int> Foo::maps { {"a", 31}, {"b", 32}};// lambda表达式方式std::map<const char*, int> Foo::maps = [] { map<const char*, int> _map; _map.insert(map<const char*, int>::value_type("a", 31)); _map.insert(map<const char*, int>::value_type("a", 32)); return _map;}();静态成员的这些异常行为很容易联想到全局变量,两者有许多相通的地方:在程序启动前完成初始化,在程序终止后销毁;存放的地方都是静态存储区而非堆栈;通过名字空间操作符获取值;在非函数块内通过函数调用或者lambda表达式完成初始化…
虽然各种面向对象编程语言都有静态变量,并且使用比例不低。但从面向对象的角度,静态成员是另一种形式的全局变量,其破坏了隔离和封装,增加了类之间的耦合,让测试变得更困难。实际编程中,应当慎用全局变量,并收紧其访问权限。
所以本质上静态成员也是全局变量,只是归属到特定类的名下。
以上就是详解c++ 静态成员变量的详细内容,更多关于c++ 静态成员变量的资料请关注其它相关文章!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
static主要有三个作用:(1)局部静态变量(2)外部静态变量/函数(3)静态数据成员/成员函数前两种C和C++都有,第三种仅在C++中有,下面分别作以下介绍
C++中静态成员函数与静态成员变量(static)这篇介绍了静态成员函数与静态成员变量,是我的读书笔记,我希望它够简短但又比较全面,起到复习的作用。如果有一些C
静态数据成员是在一个类中用关键字static声明的数据成员。在C++中,一般使用静态成员来代替C语言的全局变量,以达到数据共享。C和C++的全局变量有一定的局限
C++静态成员的类内初始化详解及实例代码一般来说,关于C++类静态成员的初始化,并不会让人感到难以理解,但是提到C++静态成员的"类内初始化"那就容易迷糊了。我
C/C++静态类和this指针详解1、静态类C++的静态成员不仅可以通过对象来访问,还可以直接通过类名来访问。classCBook{public:staticd