获取一个时间粒度整数倍的时间点

package lin;

import java.util.Calendar;

public class ClientUtil {

 private static final int secondsAnHour = 3600;
 /**
  * 获取指定时间的下一个时间粒度整数倍的时间点
  * @param lTime 传入的时间long(单位: ms)
  * @param gra 时间粒度int(单位:s)
  * @return 返回的时间 long
  */
 public static long getNextGranularityTime(long lTime, int gra) {
  long retLong = 0;
  Calendar cal = Calendar.getInstance();
  if (lTime <= 0 || gra <= 0) {
   return cal.getTimeInMillis();
  }
  if (gra >= secondsAnHour) {
   long remainder = lTime % (secondsAnHour * 1000);
   if (remainder == 0) {
    return lTime+secondsAnHour * 1000;
   } else {
    return lTime - remainder + secondsAnHour * 1000;
   }
  } else {
   int rawOffset = cal.getTimeZone().getRawOffset();
   retLong = ((lTime + rawOffset) / (gra * 1000) + 1) * gra * 1000;
   return retLong - rawOffset;
  }
 }

 /**
  * 获取指定时间的上一个时间粒度整数倍的时间点
  * @param lTime 传入的时间(单位: ms)
  * @param gra 时间粒度(单位:s)
  * @return long 返回的时间
  */
 public static long getPreGranularityTime(long lTime, int gra) {
  long retLong = 0;
  Calendar cal = Calendar.getInstance();
  if (lTime <= 0 || gra <= 0) {
   return cal.getTimeInMillis();
  }

  if (gra >= secondsAnHour) {
   return lTime - lTime % (secondsAnHour * 1000);
  } else {
   int rawOffset = cal.getTimeZone().getRawOffset();
   retLong = ((lTime + rawOffset) / (gra * 1000) + 1) * gra * 1000 - gra * 1000;
   return retLong - rawOffset;
  }
 }
}

猜你喜欢

转载自blog.csdn.net/linruby12/article/details/45044581