С++ время возврата составляет два часа

Немного новичок в С++, так что поехали;

У меня есть метод, который анализирует дату/время, однако эта дата/время всегда передается мне с 00:00:00 как чч:мм:сс. Таким образом, я хочу добавить значения текущего системного времени вместо этих значений. У меня есть методы, которые делают это, и первый метод возвращает правильное время в формате UTC.

bool CTRHTranslationRTNS::ParseDateSysTime(const char* pszString, time_t& tValue)
{
    ASSERT(pszString != NULL);

    // DateTime fields.
    enum { YEAR, MONTH, DAY, HOURS, MINS, SECS, NUM_FIELDS };

    CStringArray astrFields;

    // Split the string into the date and time fields.
    int nFields = CStringParser::Split(pszString, "- :T", astrFields);

    // Not DD/MM/YYYY HH:MM:SS format.
    if (nFields != NUM_FIELDS)
        return false;

    int anFields[NUM_FIELDS] = { 0 };

    // Parse field numbers.
    for (int i = 0; i < NUM_FIELDS; ++i)
        anFields[i] = atoi(astrFields[i]);

    tm oTime = { 0 };

        //Add System Time instead
        time_t sysyemTimeNow;
        struct tm * ptm;
        time ( &sysyemTimeNow );
        ptm = gmtime ( &sysyemTimeNow );

    // Copy fields to time struct.
    oTime.tm_mday  = anFields[DAY];
    oTime.tm_mon   = anFields[MONTH] - 1;
    oTime.tm_year  = anFields[YEAR] - 1900;
    oTime.tm_hour  = ptm->tm_hour;
    oTime.tm_min   = ptm->tm_min;
    oTime.tm_sec   = ptm->tm_sec;
    oTime.tm_isdst = -1;

    // Convert to time_t.
    tValue = mktime(&oTime);

    // Invalid field values.
    if (tValue < 0)
        return false;

    return true;
}

Во втором методе я делаю некоторое форматирование даты/времени, и это приводит к удалению 2 часов из времени.

string CTRHTranslationRTNS::ConvertDateSysTimeToDateInUTC(const string& bossDate)
{
    time_t dealDate;
    if (ParseDateSysTime(bossDate.c_str(), dealDate))
    {
        struct tm * ptm = gmtime(&dealDate);
        char buffer [80];
        strftime(buffer,80,"%Y-%m-%d %H:%M:%S",ptm);
        return string(buffer);
    }
    else
    {
        throw exception(string("Invalid date/SysTime value: ").append(bossDate).c_str());   
    }   
}

Чтобы было ясно, метод ParseDateSysTime возвращает время с правильным значением UTC 11:53, но как только

struct tm * ptm = gmtime(&dealDate);

называется изменением времени на 08:53. Предполагается, что это результат вызова метода gmtime(), но я не уверен.

Огромное спасибо

Грэм


person Graham    schedule 23.10.2012    source источник
comment
В чем именно вопрос?   -  person Sdra    schedule 23.10.2012
comment
почему есть разница в два часа во времени, когда время не было добавлено. время UTC должно быть 11:53, но оно выходит 08:53, когда gmtime вызывается во второй функции   -  person Graham    schedule 23.10.2012
comment
См. также этот stackoverflow.com/a/31474558/841108.   -  person Basile Starynkevitch    schedule 18.07.2015


Ответы (2)


Причина в том, что mktime() метод, используемый в первой функции, использует местное время, а gmtime() использует время UTC.

См. http://www.cplusplus.com/reference/clibrary/ctime/mktime/ и http://www.cplusplus.com/reference/clibrary/ctime/gmtime/ для дальнейшего объяснения.

person Hakan Serce    schedule 23.10.2012

Попробуйте эту функцию:

CTime Time2UTC(CTime original)
{
    CString Formatted = original.FormatGmt(L"%Y%m%d%H%M%S");
    int Year, Month, Day, Hour, Minute;
    if (Formatted != L"" && Formatted.GetLength() >= 12)
    {
        Year = _wtol(Formatted.Left(4));
        Month = _wtol(Formatted.Mid(4, 2));
        Day = _wtol(Formatted.Mid(6,2));
        Hour = _wtol(Formatted.Mid(8, 2));
        Minute = _wtol(Formatted.Mid(10, 2));
        CTime result(Year, Month, Day, Hour, Minute, 0);
        return result;
    }
    else
        return (CTime)NULL;
}
person Michael Haephrati    schedule 18.07.2015
comment
Спасибо за это! Спас меня от хлопот. Должен сказать, НАСТОЛЬКО раздражает то, что классы даты и времени для основных фреймворков, таких как CTime, даже НЕ ОБЯЗАНЫ встраивать функции, позволяющие вам делать такие вещи, как получение времени UTC, разбитого на компоненты, или (в случае другой класс даты/времени Microsoft, COleDateTime) построить объект даты/времени из метки времени Posix и т. д. Действительно жалко. Как будто это будет необычно для программиста, работающего с этими объектами, ХОТЯТ делать загадочные вещи, такие как правильная обработка часовых поясов или преобразование между одним API и другим. Кто бы хотел ТАКОГО... - person Dan Nissenbaum; 08.10.2016