用静态成员函数调用非静态成员变量

来源:互联网 发布:什么叫贵州大数据 编辑:程序博客网 时间:2024/06/03 12:30

用静态成员函数调用非静态成员变量

C++会区分两种类型的成员函数:静态成员函数和非静态成员函数。这两者之间的一个重大区别是,静态成员函数不接受隐含的this自变量。所以,它就无法访问自己类的非静态成员。

在某些条件下,比如说在使用诸如pthread(它不支持类)此类的多线程库时,就必须使用静态的成员函数,因为其地址同C语言函数的地址兼容。这种铜限制就迫使程序员要利用各种解决办法才能够从静态成员函数访问到非静态数据成员。

第一个解决办法是声明类的所有数据成员都是静态的。运用这种方式的话,静态的成员函数就能够直接地访问它们,例如:

class Singleton

{

public:

static Singleton * instance();

private:

Singleton * p;

static Lock lock;

};

Singleton * Singleton::instance()

{

lock.getlock(); // fine, lock is static

if (!p)

p=new Singleton;

lock.unlock();

return p;

}

这种解决方法不适用于需要使用非静态数据成员的类。

访问非静态数据成员

将参照传递给需要考量的对象能够让静态的成员函数访问到对象的非静态数据:

class A

{

public:

static void func(A & obj);

intgetval() const; //non-static member function

private:

intval;

};

静态成员函数func()会使用参照obj来访问非静态成员val

voidA::func(A & obj)

{

int n = obj.getval();

}

将一个参照或者指针作为静态成员函数的自变量传递,就是在模仿自动传递非静态成员函数里this自变量这一行为。

@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@

创建线程时,线程函数如果要设置成类的成员函数,则必须是静态成员函数,在此函数种不能使用非静态成员变量,如果要使用非静态成员变量,则一种比较适合线程的方法是:建立线程的时候把this作为CreateThread的一个参数(即第4个参数,就是那个LPVOID型的),然后线程里就对应pParam,例如:
static UINT ThreadProc(LPVOID pParam) 

     Your_Class *p=(Your_Class *)pParam; 
     //
然后用p间接使用成员变量。 

   }

线程函数是回调函数,因此它必须是静态成员函数或者是类外部声明的全局函数。