1

我想创建一个数据指针、数据大小和数据版本的静态(文件范围)表。问题是数据在外部文件中,但在外部文件中是常量。

例子:

文件1.c

    const unsigned char data1[] =
    {
    0x65, 0xF0, 0xA8, 0x5F, 0x5F,
    0x5F, 0x5F, 0x31, 0x32, 0x2E,
    0x31, 0xF1, 0x63, 0x4D, 0x43, 
    0x52, 0x45, 0x41, 0x54, 0x45,
    0x44, 0x20, 0x42, 0x59, 0x3A,
    0x20, 0x69, 0x73, 0x70, 0x56, 
// ...
    };
    const unsigned int data1_size =
        sizeof(data1) / sizeof(data1[0]);
    const unsigned int data1_version = 1;

文件2.c

    const unsigned char data2[] =
    {
    0x20, 0x44, 0x61, 0x74, 0x61,
    0x20, 0x52, 0x6F, 0x77, 0x20,
    0x3D, 0x20, 0x34, 0x38, 0x12, 
//...
    };
    const unsigned int data2_size =
        sizeof(data2) / sizeof(data2[0]);
    const unsigned int data2_version = 1;

主程序

struct Data_Info
{
  unsigned char * data_ptr;
  unsigned int    data_size;
  unsigned int    data_version;
};

extern const unsigned char data1[];
extern const unsigned int  data1_size;
extern const unsigned int  data1_version;

extern const unsigned char data2[];
extern const unsigned int  data2_size;
extern const unsigned int  data2_version;

static struct Data_Info  Data_Info_Table[] =
{
  // How to set this up??
  // The compiler wants constant expressions here,
  //    and the extern is not considered a constant expression
  // This is what I tried:
  { data1, data1_size, data1_version},
  { data2, data2_size, data2_version},
};

int main(void)
{
  return 0;
} 

我正在使用 Green Hills 编译器,4.2.3。确切的错误信息:

error #28, expression must have a constant value.

请参阅我之前的帖子:
C: External const ints in a array of const struct

注意:包含 C++ 标记,因为这也适用于 C++

4

4 回答 4

2

你有没有尝试过?(其中 X 为 0 或 1。)

struct Data_Info    
{    
  unsigned char const * data_ptr;    
  unsigned int    data_size;    
  unsigned int    data_version;    
};    

文件X.h

extern const struct Data_Info data_infoX;

文件X.c

const struct Data_Info data_infoX = { dataX, dataX_size, dataX_version };

主程序

const struct Data_Info const * Data_Info_Table[] = 
{ 
  &data_info1,
  &data_info2
}; 
于 2010-07-27T00:13:08.247 回答
1

问题是编译器不知道要放入字段的data_sizeanddata_version成员的值。有几种方法可以轻松解决这个问题。

方法一:

#include "data1.c"
#include "data2.c"

...
static struct Data_Info  Data_Info_Table[] =
{
  { data1, sizeof(data1), 1},
  { data2, sizeof(data2), 1},
};

方法二:

struct Data_Info
{
  unsigned char * data_ptr;
  unsigned int *  data_size;
  unsigned int *  data_version;
};

...

static struct Data_Info  Data_Info_Table[] =
{
  { data1, &data1_size, &data1_version},
  { data2, &data2_size, &data2_version},
};

第三种方法,正如 jyoung 已经展示的那样,是在单独的数据文件中分配成员并将它们的地址包含在 Data_Info_Table 中。

于 2010-07-27T00:22:57.027 回答
0

定义常量时,使用 extern 关键字。

于 2010-07-26T22:50:49.413 回答
0

我不是 C 专家,但是不同翻译单元的初始化顺序很可能是未定义的(我知道它在 C++ 中是未定义的,如果 C 中的行为不同,这将是一个巨大的兼容性中断),所以即使编译器允许这样做也是危险的。

现在,添加 C++ 标签很可能不会有太大帮助,因为 AFAIK 这不仅取决于语言,还取决于语言的特定版本:C89/C99。在 C++ 中,如果将初始化移动到头文件中常量的声明中,它就会起作用。同样,我不是 C 专家。

于 2010-07-26T23:34:48.530 回答