由于開發游戲服務器,常常會用到各種時間判斷。這里就在原有的標準C時間函數上做了一些擴展,使他可以方便的用在游戲中。希望能對你有用:)
如果涉及到時候,請在程序啟動的時候,先運行tzset()。這個函數會設置時間函數的全局變量timezone。下面有些函數用到了,請注意!
注意:C++Builder使用mktime,有bug!使用C++Builder的同志們要注意!(更新說明,函數有所調整,更新隨筆)
2016-3-14日更新
///取當前服務器的UTC時間
inline second_time_t get_utc_time()
{
return second_time_t(time(NULL));
}
///取本地當前時間
/**
utc時間扣除時區
*/
inline second_time_t get_local_now()
{
return get_utc_time() - timezone;
}
//取當前最小為hour的時間 也就是分和秒為0的時間
inline second_time_t get_utc_hour_time()
{
second_time_t stNow = get_utc_time();
return stNow - stNow % SECONDS_PRE_HOUR;
}
//取指定時間小時時間 也就是分和秒為0的時間
inline second_time_t get_utc_hour_time(second_time_t paramTime)
{
return paramTime - paramTime % SECONDS_PRE_HOUR;
}
///取UTC時間對應的本地時間時間結構
/**
@param [in] paramUTCTime 指定的UTC時間
@param [out] paramResult 取得的時間結果
@return struct tm * 時間結果
*/
inline struct tm * get_localtime(second_time_t paramUTCTime, struct tm * paramResult)
{
time_t t = paramUTCTime;
*paramResult = *localtime(&t);
return paramResult;
}
///將utc時間,轉換成相應的本地時間
/**
對應的逆函數是 to_utc_time
@param [in] paramUTCTime UTC時間
@return second_time_t 對應的本地時間
*/
inline second_time_t to_local_time(second_time_t paramUTCTime)
{
return paramUTCTime - timezone;
}
///生成時間
/**
參數是本地時間,返回的是UTC時間
@param [in] paramLocalTM 本地實際時間結構
@return second_time_t 對應的UTC時間
*/
inline second_time_t make_time(struct tm * paramLocalTM)
{
return second_time_t(mktime(paramLocalTM));
}
///將本地時間轉變成utc時間
/**
對應的逆函數是 to_local_time
@param [in] paramLocalTime 本地時間
@return second_time_t 對應的UTC時間
*/
inline second_time_t to_utc_time(second_time_t paramLocalTime)
{
return paramLocalTime + timezone;
}
///取本地時間對應的時間結構
/**
@param [in] paramLocalTime 指定的本地時間
@param [out] paramResult 取得的時間結果
@return struct tm * 時間結果
*/
inline struct tm * get_localtime_by_local(second_time_t paramLocalTime, struct tm * paramResult)
{
time_t t = to_utc_time(paramLocalTime);
*paramResult = *localtime(&t);
return paramResult;
}
///判斷時間是不是同一天
inline bool is_same_day(second_time_t paramUTCT1, second_time_t paramUTCT2)
{
return (to_local_time(paramUTCT1) / SECONDS_PRE_DAY) == (to_local_time(paramUTCT2) / SECONDS_PRE_DAY);
}
///取本周一零點時間
/**
@param [in] paramUTCTime 指定的utc時間
@return second_time_t 周一零點的utc時間
*/
inline second_time_t get_local_monday_zero_time(second_time_t paramUTCTime)
{
struct tm tNow;
get_localtime(paramUTCTime, &tNow);
int iWeekDay = tNow.tm_wday;
if (iWeekDay == 0) //如果是星期天
{
iWeekDay = 6;
}
else
{
iWeekDay --;
}
second_time_t stLocal = to_local_time(paramUTCTime);
stLocal = stLocal - (stLocal % SECONDS_PRE_DAY) - iWeekDay * SECONDS_PRE_DAY;
return to_utc_time(stLocal);
}
//是否是禮拜六和禮拜天
inline bool is_weekend_day(second_time_t paramUTCTime)
{
second_time_t stMondayTime = get_local_monday_zero_time(paramUTCTime);
return paramUTCTime >= stMondayTime + SECONDS_PRE_DAY * 5;
}
//判斷是不是同一個星期
inline bool is_same_week(second_time_t paramUTCTime1, second_time_t paramUTCTime2)
{
return get_local_monday_zero_time(paramUTCTime1) == get_local_monday_zero_time(paramUTCTime2);
}
//計算相差的天數
inline int calc_diff_days(second_time_t paramUTCT1, second_time_t paramUTCT2)
{
return int(to_local_time(paramUTCT1) / SECONDS_PRE_DAY) - (to_local_time(paramUTCT2) / SECONDS_PRE_DAY);
}
//計算是不是同一個月
inline bool is_same_month(second_time_t paramUTCT1, second_time_t paramUTCT2)
{
struct tm t1;
struct tm t2;
get_localtime(paramUTCT1, &t1);
get_localtime(paramUTCT2, &t2);
return (t1.tm_year == t2.tm_year) && (t1.tm_mon == t2.tm_mon);
}
//取指定時間的0點時間
inline second_time_t get_zero_time(second_time_t paramUTC)
{
second_time_t stLocal = to_local_time(paramUTC);
return to_utc_time(stLocal - (stLocal % SECONDS_PRE_DAY));
}
//cxy 取指定時間的0點時間
inline second_time_t get_day_second()
{
auto utc = get_utc_time();
auto zt = get_zero_time(utc);
return utc - zt;
}
//取定本地時間 下一天0點 對應的UTC時間
inline second_time_t get_next_day_zero_time(second_time_t paramUTC)
{
struct tm t;
get_localtime(paramUTC, &t);
t.tm_mday++;
t.tm_hour = 0;
t.tm_min = 0;
t.tm_sec = 0;
return make_time(&t);
}
//取定本地時間 下一周0點 對應的UTC時間
inline second_time_t get_next_week_zero_time(second_time_t paramUTC)
{
struct tm t;
get_localtime(paramUTC, &t);
int day = 7 - t.tm_wday;
t.tm_mday += day;
t.tm_hour = 0;
t.tm_min = 0;
t.tm_sec = 0;
return make_time(&t);
}
//取定本地時間 下一幾的0點 對應的UTC時間
inline second_time_t get_next_week_time(second_time_t paramUTC,int day)
{
struct tm t;
get_localtime(paramUTC, &t);
t.tm_hour = 0;
t.tm_min = 0;
t.tm_sec = 0;
//同一天
if (t.tm_wday == day)
return get_next_week_time(paramUTC + SECONDS_PRE_DAY, 1);
while (t.tm_wday != day)
{
t.tm_wday += 1;
t.tm_wday %= 7;
t.tm_mday += 1;
}
return make_time(&t);
}
//取指定本地時間 當前月1號0點 對應的UTC時間
inline second_time_t get_month_1_day_zero_time(second_time_t paramUTC)
{
struct tm t;
get_localtime(paramUTC, &t);
t.tm_mday = 1;
t.tm_hour = 0;
t.tm_min = 0;
t.tm_sec = 0;
return make_time(&t);
}
//取指定本地時間,下個月1號0點 對應的UTC時間
inline second_time_t get_next_month_1_day_zero_time(second_time_t paramUTC)
{
struct tm t;
get_localtime(paramUTC, &t);
t.tm_mon++;
if (t.tm_mon > 11)
{
t.tm_year++;
t.tm_mon = 0;
}
t.tm_mday = 1;
t.tm_hour = 0;
t.tm_min = 0;
t.tm_sec = 0;
return make_time(&t);
}