7

我已经阅读了解决方案const A a[3] = { {0,0}, {1,1}, {2,2} },,但在我的程序const中无法使用:

class Paper: public PaperQueue{  
  ...
  protected:
    typedef int (Utils::*funcPtr) (int, int); //I use external function there
    funcPtr p;                               
    Utils* fptr; 
  public:
    int pricefunc(){     
      addprice = (fptr->*p) (t,price);
    }

    Paper(int n, unsigned int pr):PaperQueue(n){         
       ...
       p=&Utils::commonpricefunc;    
    }
    void Put(int a){ 
       ...
    }
  ...
}    

class Bank{ 
  ...
  void Buy(Paper &p){
   (/*this function modifies many parameters in 'p'*/)
  ...
  }
  ...
}

int main(){
Bank B;    
int pn=5;
/* ? */ const Paper p[pn] = {{5,15},{5,15},{5,15},{5,15},{5,15}}; /* ? */
int paperloop=0;
...
p[paperloop].Put(p[paperloop].addprice);
B.Buy(p[paperloop]);
...

这给了我很多错误(使用pricefunc(),Put(),Buy(),...),或者只是“可变大小的对象'p'可能未初始化”。有没有办法让这个数组工作?(如果不将任何参数传递给构造函数,一切正常!)

4

2 回答 2

3

您不能对类(非 POD)使用初始化列表,因为这会绕过对构造函数的调用。您必须通过以下方式将其更改为 POD 或使用 std::vector:

如果该类是可复制的,那么您可以创建一个 std::vector 并用您想要的值填充它:

const vector<Paper> papers(5, Paper(5, 15));

如果你想用不同的值初始化它,你可以使用一个初始化列表,但这仅在 C++11 中支持:

const vector<Paper> papers = {Paper(1, 1), Paper(2, 2)};

如果没有 C++11,您将不得不一个一个地添加元素,但是您不能将向量设为 const:

vector<Paper> papers;
papers.push_back(Paper(1, 1));
papers.push_back(Paper(2, 2));
于 2012-11-23T04:54:10.207 回答
0

请检查下面的代码,它可以编译:

class Paper {
public:
    int x, y;
}; 

int main() {
    Paper p[5] = {{5,15}, {5,15}, {5,15}, {5,15}, {5,15}};
}

请参考这篇文章了解更多详细信息,我认为它解释得很好

于 2012-11-23T04:35:50.807 回答