假设函数
void foo(uint8_t value)
{
somearray[some_idx] = value;
}
CodeVision 产生以下
ST -Y,R26 // the parameter "value" is in R26
; value -> Y+0
LDS R30,_some_idx
LDI R31,0
SUBI R30,LOW(-_somearray)
SBCI R31,HIGH(-_somearray)
LD R26,Y
STD Z+0,R26
R26 到 Y 和从 Y 的存储和加载是完全没有必要的,而且是 2+2 个循环。我只是想了解 CodeVision 为什么这样做,因为它通常非常聪明。