数组大小取决于 sizeof() 结构字段

Posted

技术标签:

【中文标题】数组大小取决于 sizeof() 结构字段【英文标题】:array size dependent on sizeof() a struct field 【发布时间】:2010-11-28 21:46:08 【问题描述】:

我有一个包含一组结构的全局包含文件。在我的程序的某个地方,我有一个包含成员数组的类。此数组中的元素数量取决于特定结构中特定字段的大小。我想让它在结构字段的大小发生变化时自动更新数组大小。我已经能够使用以下表达式成功地做到这一点:

bool shadowChkBox[sizeof(FSCconfigType::WriteEn)*8*MAX_FSCS];

FSCconfigType 是结构类型,WriteEn 是字段之一。现在这有效,但仅在 ubuntu 上有效。在 RHEL 5 上,编译器将其声明为错误。我还有什么其他选择可以做到这一点?我正在使用 Qt。

【问题讨论】:

你在 RH 上遇到了什么错误? 我怀疑这与您使用的 GCC 版本有关,而不是与 Linux 的版本有关。 可以直接使用字段的类型,而不是通过字段引用吗?我猜不是(因为这是 sizeof 可能会改变的原因),但检查一下也无妨。 @steve 实际上这就是 sizeof 可能改变的原因 @yan bellavance,我同意您不应该要求您的用户升级 gcc。我只是想澄清这个问题。我认为代码应该可以编译,如果它是旧版本 gcc 中的错误,那么我认为您将遇到更丑陋的解决方法。 【参考方案1】:

这是一个可能的答案:

#include <iostream>

struct A

        int a;
        int b;
        int c;
;

bool items[sizeof(reinterpret_cast<A *>(0)->b)];

int main()

        std::cout << sizeof(reinterpret_cast<A *>(0)->b) << ",";
        std::cout << sizeof(items) << std::endl;
        return 0;

【讨论】:

谢谢它的工作。一个问题。你到底在用(0)做什么?似乎是一个空地址。 sizeof 的参数除了确定其类型外,不会被计算。将NULL 转换为A * 与获取具有指向A 的指针类型的任何方法一样好。 (例如,( A*)printf(0) 也可以。)【参考方案2】:

一个脆弱的答案是获取 WriteEn 和下一个字段的 offsetof 值的差异(否则,整个结构的大小)。

由于基于对齐的填充,这可能会给出比 sizeof 稍大的答案。

一个更大的问题是,如果您重新排列字段而不修复此问题会发生什么 - 但如果您不顾一切,这可能是一个选择。

【讨论】:

【参考方案3】:
#include <iostream>

struct C

    int iv;
    void* pv;
    char buf[128];
;

template< typename TObj, typename TFieldType >
std::size_t field_size( TFieldType (TObj::*) )

    return sizeof(TFieldType);


int main() 

    std::cout << field_size(&C::iv) << std::endl;
    std::cout << field_size(&C::pv) << std::endl;
    std::cout << field_size(&C::buf) << std::endl;

【讨论】:

以上是关于数组大小取决于 sizeof() 结构字段的主要内容,如果未能解决你的问题,请参考以下文章

sizeof()函数的使用——————Badboy

如何获取数组的大小? [复制]

sizeof 运算符在 C# 中给出结构的额外大小 [重复]

C++中结构体的大小

sizeof和strlen的区别

结构的 sizeof 会受数组元数据的影响吗?