繁体   English   中英

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

[英]Holding an Integer array in a struct. Cannot defne struct properly

我想在我的结构中保存一个整数数组

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);
      }

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

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

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

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

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

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

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

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

int colRatios[3];

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

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

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

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM