最近在写代码的时候遇见了一个bug,在获取当前时间戳的毫秒时,我自己测试的时候总是OK的,但是测试那边总是测不对,之前一直以为是因为我存储的类型的不对,从long long类型从lld改成llu,然后又查了查,百度了看看这个毫秒是要怎么存储的,大家博客上面都是用ld存的,所以ld我也试了,但是都没有解决问题,为了要解决问题,我在每次调用了gettimeofday()函数之后,都是直接将获取的数字转化成字符串,然后又是各种lld、llu和ld,都是不对的,然后找原因,直到在网上看了一个博文:gettimeofday取毫秒的溢出问题,然后想到了机顶盒可能是32位系统,虽然之前怀疑过是因为32位和64位的原因溢出来,但是这次试了试,机顶盒里面的long类型是4个字节,所以机顶盒是32位系统,uname -a查询了机顶盒的信息,机顶盒是arm7,然后是因为在获取时间戳的时候,tv.tv_sec*1000在32位系统上溢出了,然后.....
之后的处理方法是将tv.tv_sec用long long类型存储,将long类型强转成long long类型,然后在进行毫秒的运算。
好像记得自己之前打比赛的时候也遇见过这样的情况,但不是因为系统32位64位的因素,只是简单的运算溢出了,最后的解决方法都是强转。