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;
}
}
}