天天看點

VC6.0中友元函數無法通路類私有成員的解決辦法-------VC6.0的bug

舉個例子:

  1. #include<iostream>
  2. using namespace std;
  3. class cylinder
  4. {
  5.     friend istream operator>>(istream& is,cylinder &cy);
  6. public:    
  7.     inline double square()
  8.     {       return length*(width+height)*2+width*height*2;    }
  9.     inline double volume()
  10.     {      return length*width*height;      }
  11. private:
  12.     double length;
  13.     double width;
  14.     double height;
  15. };
  16. istream operator>>(istream is,cylinder &cy)
  17. {
  18.     cout<<"input length:"<<endl;
  19.     is>>cy.length;
  20.     cout<<"input width:"<<endl;
  21.     is>>cy.width;
  22.     cout<<"input height:"<<endl;
  23.     is>>cy.height;
  24.     return is;
  25. }
  26. int main()
  27. {
  28.     cylinder first;
  29.     cin>>first;
  30.     cout<<first.square()<<endl;
  31.     cout<<first.volume()<<endl;
  32.     return 0;
  33. }

這些代碼在VC6.0中不能被編譯通過:提示不能通路私有成員,沒有這個通路權限

改成這樣就可以了,代碼如下:

  1. #include<iostream>
  2. using std::cin;
  3. using std::endl; using std::cout;
  4. using std::ostream;
  5. using std::istream;
  6. using std::ostream;
  7. class cylinder
  8. {
  9.     friend istream operator>>(istream& is,cylinder &cy);
  10. public:    
  11.     inline double square()
  12.     {       return length*(width+height)*2+width*height*2;    }
  13.     inline double volume()
  14.     {      return length*width*height;      }
  15. private:
  16.     double length;
  17.     double width;
  18.     double height;
  19. };
  20. istream operator>>(istream is,cylinder &cy)
  21. {
  22.     cout<<"input length:"<<endl;
  23.     is>>cy.length;
  24.     cout<<"input width:"<<endl;
  25.     is>>cy.width;
  26.     cout<<"input height:"<<endl;
  27.     is>>cy.height;
  28.     return is;
  29. }
  30. int main()
  31. {
  32.     cylinder first;
  33.     cin>>first;
  34.     cout<<first.square()<<endl;
  35.     cout<<first.volume()<<endl;
  36.     return 0;
  37. }

原因:

這據說是VC的一個經典BUG。和namespace也有關. 

隻要含有using namespace std; 就會提示友員函數沒有通路私有成員的權限。 

解決方法:去掉using namespace std;換成更小的名字空間。 

例如: 

含有#include <string>就要加上using std::string 

含有#include <fstream>就要加上using std::fstream 

含有#include <iostream>就要加上using std::cin; using std::cout; using std::ostream; using std::istream; using std::endl; 等等,需要什麼即可通過using聲明什麼.

下面給出流浪給的解決辦法:

//方法一:

//提前聲明

class cylinder;

istream &operator>>(istream& is,cylinder &cy);

//方法二:

//不用命名空間 或者 像晨雨那樣寫

#include<iostream.h>

//方法三:

class cylinder

{

    friend istream &operator>>(istream& is,cylinder &cy)//寫在類裡面

    {

        cout<<"input length:"<<endl;

        is>>cy.length;

        cout<<"input width:"<<endl;

        is>>cy.width;

        cout<<"input height:"<<endl;

        is>>cy.height;

        return is;

    }

..........

//方法四:打SP6更新檔,貌似不好使。。。(呵呵,是貌似也沒用)

//方法五:換别的對标準C++支援好的編譯器,如DEV C++/。。。(呵呵)

如果要重載<<運算符的話,就

要用 using std::istream;

using std::ostream;因為這種形式才能重載流輸入和輸出運算符