第一个问题,所以我希望它可以理解!
我正在初始化一个指向复合文字的指针,它是一个结构指针数组。然后我可以像通常使用指针数组一样使用这个指针。
typedef struct
{
uint32_t test1;
uint32_t test2;
uint32_t test3;
uint32_t test4;
uint32_t test5;
uint32_t test6;
uint32_t test7;
uint32_t test8;
uint32_t test9;
uint32_t test10;
uint32_t test11;
} TestStruct;
TestStruct* TestStructArray = (TestStruct[])
{
{
.test1 = 69,
},
{
.test1 = 69,
},
{
.test1 = 0,
},
};
当我稍后尝试遍历这个数组时,我使用 size_t 类型的变量作为循环计数器,并使用 [] 数组表示法访问数组的成员。
void main(void)
{
size_t ArrIdx = 0U;
while(TestStructArray[ArrIdx].test1 != 0U) \\\\\ <-- warning: (752) conversion to shorter data type
{
LocalTestFunction();
ArrIdx++;
}
}
当数组大小低于某种大小阈值时,编译器会给出以下警告:(752) 转换为更短的数据类型。向 struct 添加更多成员,或向 struct 数组添加更多成员会删除警告。即.. 在此示例中,初始化数组的另一个成员会消除编译器错误。
此警告似乎指向我使用 size_t 类型的索引访问数组成员的行。似乎编译器用于数组索引的类型不是常量,实际上取决于数组的大小。这使得防止截断或未使用的内存变得非常困难。
我已经在一个全新的项目中编译了这个测试代码,并且行为仍然存在。
我是疯了还是我发现了优化的一些有趣的怪癖?
我的构建环境如下:
- MPLAB X v5.35
- XC8 v2.10
- C 库中的 C99 标准和链接
- 警告级别:-9
- 器件:PIC18F46K20
- 优化:空间(PRO)