c++ - 在结构中保存一个整数数组。无法正确定义结构

标签 c++ arrays libharu

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

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++,它仍然需要在初始化时知道​​大小(而不是来自以后的分配,就像在分配给数组的伪代码中一样)。还有另一个称为“灵活数组”的扩展,其中最后一个成员可以在没有大小的情况下声明,然后您手动为整个结构分配足够的内存,加上您希望数组有多大。

关于c++ - 在结构中保存一个整数数组。无法正确定义结构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14756826/

相关文章:

C++ sendto() 给出 "invalid conversion from ‘int (*)(int, int, int)throw ()’ 到 ‘int’ "错误

c++ - 如果所包含的对象也继承,如何定义相互继承的容器? (以QObject为基础)

java - 如何在整数数组中找到重复的整数序列?

php - 我怎样才能对这个数组进行排序

java - Java 中的基本井字棋

iphone - 如何在 iOS 上使用 libharu 以 2/3 行显示字符串?

iphone - 谁能告诉我如何使用 libHaru 库创建带有文本注释的 PDF

java - 什么使用 libharu c++ 或我文本 java

c++ - boost::序列化和循环引用反序列化

c++ - NvAPI NVAPI_INTERFACE 缺少显式类型