我的踩坑记录

2021.5.28 【c语言】sizeof测量结构体大小

struct a
{
    
    
	float a;
	float b;
};
typedef struct a* a_t;
printf("sizeof(a) = %d\r\n",sizeof(a_t));//出错的情况,sizeof的结果为4
printf("sizeof(a) = %d\r\n",sizeof(struct a));//对的情况,sizeof达到了测量结构体的目的
  • 错误描述:使用sizeof测量结构体时测量的结果为4
  • 错误分析:sizeof里的参数是一个指针,我测量的是指针的大小,所以为4,没有测量到结构体。

2021.5.30 【FPGA】modelsim testbench无法得到波形

always #(SYS_PERIOD/2)                                                
// optional sensitivity list                           
// @(event1 or event2 or .... eventn)                  
begin                                                  
// code executes for every event on sensitivity list   
// insert code here --> begin                          
sys_clk <= ~sys_clk;                                                   
//@eachvec;                                              
// --> end                                             
end   
  • 错误描述:modelsim仿真无法得到波形
  • 错误分析:没有注释掉@eachvec
  • 参考:https://wenwen.sogou.com/z/q717010174.htm

其实虽然不明白那个变量的意思 但是也并非完全无用 在仿真组合逻辑的时候 如果不用到时钟信号 那么 reg eachvec 和@eachvec都是不能注释掉的 否则看不到仿真波形 所以可以推断 eachvec应该和时序逻辑中的时钟信号一样都是驱动信号:)------郁金香
“虽然不知道那个变量是什么,但是把@eachvec;那一行注释掉的话你仿真才能得到一段很长的波形,不然你的仿真时间就非常短,如果在它之前有在这个always过程块里规定时钟信号的翻转的话,这个时钟信号也不会翻转。总之,注释掉它”------ryshjx说的基本是正确的 如果你有驱动时钟信号在 那就按照上述做就好了~

Guess you like

Origin blog.csdn.net/weixin_43810563/article/details/117368619