其實我們從直觀上可以很好的理解靜態成員函數不能調用非靜態成員變量這句話因為無論是靜態成員函數還是靜態成員變量,它們
都是在類的范疇之類的,及在類的整個生存周期里始終只能存在一份。然而非靜態成員變量和非靜態成員函數是針對類的對象而言。
然而從本質上來說類的靜態成員函數的函數形參中沒有默認的this指針,導致不能調用具體實例對象的成員。
下面我們來測試一下:
先在靜態成員函數中調用靜態成員變量:
1 #include <iostream> 2 using namespace std; 3 4 class vpoet 5 { 6 public: 7 static int a; 8 int b; 9 10 public: 11 vpoet(int data) 12 { 13 b=data; 14 } 15 16 static void statictestfun1() 17 { 18 cout<<"static a="<<a<<endl; 19 } 20 }; 21 22 int vpoet::a=10; 23 24 int main() 25 { 26 vpoet *V; 27 V=new vpoet(5); 28 vpoet::statictestfun1(); 29 return 0; 30 }
調用成功,截圖如下:

現在我們再靜態成員函數中調用非靜態成員變量:
1 #include <iostream> 2 using namespace std; 3 4 class vpoet 5 { 6 public: 7 static int a; 8 int b; 9 10 public: 11 vpoet(int data) 12 { 13 b=data; 14 } 15 16 static void statictestfun1() 17 { 18 cout<<"static b="<<b<<endl; 19 } 20 }; 21 22 int vpoet::a=10; 23 24 int main() 25 { 26 vpoet *V; 27 V=new vpoet(5); 28 vpoet::statictestfun1(); 29 return 0; 30 }
編譯下提示了錯誤:

大意是在靜態成員函數中引用了類的非靜態成員變量b。
其實這里可以再深入分析下:
靜態成員變量的函數形參中沒有默認的this指針指向類對象本身。所以當我們調用對象的非靜態成員變量的時候它不能識別該變量
然而對於靜態成員變量而言,其存在於整個類中,為每個類對象共有,所以就算沒有默認的this形參仍然可以識別該靜態成員變量
