zoukankan      html  css  js  c++  java
  • 机顶盒 gettimeofday()获取毫秒溢出

      最近在写代码的时候遇见了一个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位的因素,只是简单的运算溢出了,最后的解决方法都是强转。

  • 相关阅读:
    HDU6397
    容斥原理推导错排通项公式
    重复排列的证明
    圆排列证明
    rock-paper-scissors
    The more, The Better
    趁着情人节写点东西
    分层图最短路问题
    背包问题是否装满问题
    Python面向对象编程扑克牌发牌程序,另含大量Python代码!
  • 原文地址:https://www.cnblogs.com/chenyang920/p/7291166.html
Copyright © 2011-2022 走看看