今天遇到一个问题,使用一个UINT64的变量调用gettimeofday()接口获取时间,用来计时。可发生了在下一次调用的时候UINT64变量变为0或者为UINT32的数据类型,向下排查了好久,才现在是在上面有个方法在调用的时候地址传递错误,导致了下面的地址也发生了偏移。在C语言中需要时刻记住地址偏移的问题。数据异常不一定需要向下查询,也可以向上查询。
PS:因为全局中都没有在对UINT64这个变量进行过操作,所以没有怀疑过在那里发生了二次赋值。排查后才发现,原来是在对结构体的另外一个成员做处理的时候传递地址错误导致的另外一个位置发生了错误。