所以我从Stephen Prata的书中学习C ++,我想做一个练习......所以问题是:
我想在结构中使用std :: valarray,在这样的类中:
class Wine
{
private:
struct Pair
{
std::valarray<int> valYear;
std::valarray<int> valBottlesNum;
};
int m_yearNum;
Pair m_numericData;
public:
Wine();
Wine(int, const int[], const int[]);
};
并通过成员初始化列表初始化:
Wine::Wine(int yearNum, const int year[], const int bottlesNum[])
: m_yearNum(yearNum),
m_numericData.valYear(yearNum, year),
m_numericData.valBottlesNum(yearNum, bottlesNum)
{}
但它只是不想工作。不知怎的,编译器不喜欢这个&#34;。&#34;访问初始化列表中 m_numericData 结构的成员。
我可以放弃 Pair struct并将 valYear 和 valBottlesNum 作为一个简单的类成员变量,并像这样初始化它们...... / p>
Wine::Wine(, int yearNum, const int year[], const int bottlesNum[])
: m_yearNum(yearNum), m_valYear(yearNum, year), m_valBottlesNum(yearNum, bottlesNum)
{}
但我真的想知道如何解决这个问题。
感谢adavnce!
答案 0 :(得分:1)
您可以将各个初始化移动到构造函数的主体中:
Wine::Wine(int yearNum, const int year[], const int bottlesNum[])
: m_yearNum(yearNum)
{
m_numericData.valYear = std::valarray<int>(yearNum, year);
m_numericData.valBottlesNum = std::valarray<int>(yearNum, bottlesNum);
}
或者,为Pair
提供自己的构造函数。
答案 1 :(得分:1)
您尝试使用的valarray
constructor对数据采用T const*
,并且std::size_t
参数指示第一个参数指向的数组元素的数量。如果您可以使用C ++ 11,那么将yearNum
更改为std::size_t
,然后您可以使用 list-initialization ,然后聚合初始化Pair
。
Wine::Wine(std::size_t yearNum, const int year[], const int bottlesNum[])
: m_yearNum(yearNum)
, m_numericData{{year, yearNum}, {bottlesNum, yearNum}}
{}