事实上这个心得与按键选择并没有什么关系,只是在做按键选择时恰好发现了一些东西。
先贴代码
process(key_0)
begin
case flag is
when timeshow=>
corrkey_3<=key_3;
when clock=>
clockey_1<=key_1;
clockey_2<=key_2;
clockey_3<=key_3;
when stopwatch=>
stopkey_1<=tempkey_1;
stopkey_2<=tempkey_2;
stopkey_3<=tempkey_3;
when downtiming=>
downkey_1<=tempkey_1;
downkey_2<=tempkey_2;
downkey_3<=tempkey_3;
when correct=>
corrkey_1<=key_1;
corrkey_2<=key_2;
corrkey_3<=key_3;
when others=>null;
end case;
end process;
仿真结果
在这个状态语句里timeshow是始态,由key_0触发状态变换。可以观察到,在始态时,其他所有状态的赋值语句都没有生效,这就意味着其他状态被赋值的信号或输出全都为不定态。不定态是非常碍事的,经常会导致无法解释的bug。所以需要在始态给这些信号赋初值
process(key_0)
begin
case flag is
when timeshow=>
corrkey_3<=key_3;
stopkey_1<='1';
stopkey_2<='1';
stopkey_3<='1';
downkey_1<='1';
downkey_2<='1';
downkey_3<='1';
when clock=>
clockey_1<=key_1;
clockey_2<=key_2;
clockey_3<=key_3;
when stopwatch=>
stopkey_1<=tempkey_1;
stopkey_2<=tempkey_2;
stopkey_3<=tempkey_3;
when downtiming=>
downkey_1<=tempkey_1;
downkey_2<=tempkey_2;
downkey_3<=tempkey_3;
when correct=>
corrkey_1<=key_1;
corrkey_2<=key_2;
corrkey_3<=key_3;
when others=>null;
end case;
end process;
这样子问题就解决了