在学习之前,我们要首先回顾一下复数类:C++学习4:详解不带指针的类(侯捷Complex类为例)。
1、non_static的成员函数是通过this来调用non_static的对象:
complex c1,c2,c3;
cout << c1.real();
cout << c2.real();
和下面的内容是一样的:
complex c1,c2,c3;
cout << complex::real(&c1); //这里c1的地址(&符号在这里是地址)就是c1成员函数中的this.
cout << complex::real(&c2); //这里c2的地址(&符号在这里是地址)就是c2成员函数中的this.
可见,这个成员函数real()是通过this调用。
2、this:小括号里面一定不能写,函数里面可写可不写,不写时编译器会帮你加上。
上面的real,正常写法(1)和用完整写出来(2)如下:
double real() const { return re;} ***************************1
double real( this ) const { return this->re;} ***************2
1、static加在对象前,就和对象脱离了,就不再属于对象。它存在一个其他的内存区域,变为静态数据,只有一份。(银行账户为例:用户类比非静态对象,利率类比静态对象)
2、static加在成员函数前,和其他的成员函数基本相同。唯一不同之处是静态成员函数没有this!也就不能像其他成员函数那样去访问或处理对象。用于处理静态数据。
下例:
class Account
{
public:
static double m_rate;
static void set_rate(const double& x) { m_rate = x; }
};
Account::m_rate = 8.0;
int main()
{
Account::set_rate(5.0); ***** 1
Account a;
a.set_rate(3.0); ************* 2
}
可知:静态数据在类中声明过后还要在外层定义,这个定义可以如例赋初值,也可以不赋值。
静态成员函数的调用方法有两种:1.通过类名直接调用;2.通过对象调用。
一般成员函数通过对象调用时都会有this指针,然而静态成员函数中并没有指针!
前面有提到过这个部分:Complex类的1.3.3.5。
单例模式的诉求:创建一个类,希望它只产生一个对象。
把ctor放在private区的结果是,没有任何对象可以创建它了,除了static的。外界想取得这个对象,必须用static函数,也就是静态函数。通过类名调用静态函数取得这个对象后,才能进行这个对象其他的public操作。
class A
{
public:
static A& getInstance() { return a; };
setup(){...}
private:
A();
A(const A& rhs);//这两个构造函数在private里面
};
A::getInstance().setup();
这里a是static的,在内存中一直存在。为了让内存更进一步得以使用可进行如下改进:
class A
{
public:
static A& getInstance();
setup(){...}
private:
A();
A(const A& rhs);//这两个构造函数在private里面
};
A& A::getInstance()
{
static A a;
return a;
}
A::getInstance().setup();