在结构中保存Integer数组。无法正确定义结构

时间:2013-02-07 17:06:28

标签: c++ arrays libharu

我想在我的struct

中保存一个整数数组
struct HPDF_TableAttributes
{
    HPDF_REAL rows;
    HPDF_REAL cols;
    HPDF_REAL rowH;
    HPDF_REAL colW;
    HPDF_REAL tabX;
    HPDF_REAL tabY;
    HPDF_REAL tabH;
    HPDF_REAL tabW;
    HPDF_Font font;
    HPDF_REAL fontSize;
    int colRatios[];     /// HERE
};

似乎无论我怎么做,编译器都希望我在这里初始化它?我必须这样做吗?我正在尝试按照以下方式执行某些操作。

    HPDFTableAttributes oTACent;
    oTACent.rows = 3;   oTACent.cols = 3;
    oTACent.rowH = 20;  oTACent.colW = pageWidth-70/oTACent.cols;
    oTACent.tabH = oTACent.rows * oTACent.rowH;
    oTACent.tabW = oTACent.cols * oTACent.colW;
    oTACent.tabX = 35;  oTACent.tabY = pageHeight - oTACent.tabH - 45;
    oTACent.font = fontTimesBold; oTACent.fontSize = 20;
    oTACent.colRatios = [1, 1, 2];  /// HERE

然后我将这些属性发送到我的函数,这使我成为一个表,并使用此整数数组中的值与沿相同行的空间列的比率。

void CReport::putTableOnPdf(HPDF_Page page, HPDFTableAttributes tabAtt, array_2d<CString> tabDat)
 {
     // Table Outline
     HPDF_Page_SetLineWidth (page, 1);
     HPDF_Page_Rectangle (page, tabAtt.tabX, tabAtt.tabY, tabAtt.tabW, tabAtt.tabH);
     // Table row lines
     HPDF_REAL rowsPut = 0;
     while(rowsPut < tabAtt.rows)
     {
         rowsPut++;
         HPDF_Page_MoveTo (page, tabAtt.tabX, tabAtt.tabY + rowsPut*tabAtt.rowH);
         HPDF_Page_LineTo (page, tabAtt.tabX + tabAtt.tabW, tabAtt.tabY + rowsPut*tabAtt.rowH);
     }
     // Table col lines
     /*int colRatioSum = 0;
     for(int i = 0; i < tabAtt.colRatios.length; i++)
         colRatioSum += tabAtt.colRatios[i];
     tabAtt.colW = tabAtt.colW / colRatioSum;*/ /// HERE
     HPDF_REAL colsPut = 0;
     while(colsPut < tabAtt.cols)
     {
         colsPut++;
         HPDF_Page_MoveTo (page, tabAtt.tabX + colsPut*tabAtt.colW, tabAtt.tabY);
         HPDF_Page_LineTo (page, tabAtt.tabX + colsPut*tabAtt.colW, tabAtt.tabY + tabAtt.tabH);
     }
     HPDF_Page_Stroke (page);
      }

2 个答案:

答案 0 :(得分:2)

在C ++中,数组的大小是其类型的一部分。*有一个特殊的规则允许数组声明从初始化器中推断出它的大小,因此你不必总是明确地写出类型。

您也可以在某些情况下编写和使用不完整的类型,但是您无法对需要完整类型的类型执行任何操作。

所以这里的问题是你正在编写一个不完整的类型并用它做一些需要完整类型的东西(即声明该类型的对象)。添加初始化程序是声明数组大小的一种方法,从而完成了类型,从而避免了错误。

如果您真正想要的是“并且最后一个字段是整数的集合”,那么您需要使用可以表示该类型的类型(同样,数组具有固定数量的元素)。在C ++中,最明显的解决方案是std::vector<int>。使用std::vector,您几乎可以完全编写伪代码:

oTACent.colRatios = {1, 1, 2};

您可能会看到但不应该写的另一个选项是使用指针。定义C ++使得您可以使用指向数组元素的指针,类似于数组。由于指针类型不包含数组大小,因此相同的指针类型可以与任何大小的数组一起使用。

*一些编译器支持可变长度数组成员作为扩展,其中数组的大小是在初始化结构时确定的,但这不是标准C ++,它仍然需要在初始化时知道​​大小(而不是从后面的赋值,比如在您分配给数组的伪代码中)。还有另一个名为“灵活数组”的扩展,其中最后一个成员可以在没有大小的情况下声明,然后为整个结构体手动分配足够的内存,加上你想要的数组大。

答案 1 :(得分:0)

数组的大小必须在声明时知道,因为它是它的类型。所以你应该改为:

int colRatios[3];

此外,分配给数组不会像您尝试的那样工作:

oTACent.colRatios = [1, 1, 2];

C ++中没有这样的语法。如果你想轻松地分配这样的值,你可以使用C ++ 11和std :: vector:

std::vector<int> colRatios;
// ...
oTACent.colRatios = {1, 1, 2};