У меня есть функция, которую я написал (если есть хорошая стандартная замена, дайте мне знать...)
time_t get_unix_time(string time_str) {
time_t loctime;
time(&loctime);
struct tm *given_time;
time_str = time_str.substr(0, time_str.find_first_of('.'));
replace(time_str.begin(), time_str.end(), ':', ',');
replace(time_str.begin(), time_str.end(), '-', ',');
replace(time_str.begin(), time_str.end(), '/', ',');
replace(time_str.begin(), time_str.end(), ' ', ',');
given_time = localtime(&loctime);
vector<string> trecord = split_string(time_str, ',');
given_time->tm_year = atoi(trecord.at(0).c_str()) - 1900;
given_time->tm_mon = atoi(trecord.at(1).c_str()) - 1;
given_time->tm_mday = atoi(trecord.at(2).c_str());
given_time->tm_hour = atoi(trecord.at(3).c_str());
given_time->tm_min = atoi(trecord.at(4).c_str());
given_time->tm_sec = atoi(trecord.at(5).c_str());
return mktime(given_time);
}
Входные данные (time_str) функции имеют формат 1970-01-01 00:00:00.0. Функция split_string() разбивает строку time_str
на вектор, содержащий:
{ 1970, 01, 01, 00, 00, 00 }
который используется для заполнения структуры заданного_времени.
Я написал функцию для ее проверки и передал именно этот ввод (начало эпохи). Однако время, которое он мне возвращает, составляет 21 600, то есть 1970-01-01 06:00:00 или UTC+6. Ожидаемый результат: 0 (начало эпохи).
Примечание: я нахожусь в часовом поясе Центрального региона США, то есть UTC – 6. В полночь 1 января 1970 года по центральному поясному времени время по UTC будет 1 января 1970 года в 06:00:00.
Есть ли в моей функции что-то, что делает ее специфичной для моего часового пояса? Я делаю что-то неправильно в этой функции, или я могу сделать что-то другое, чтобы сделать ее независимой от зоны или, по крайней мере, всегда UTC.
TZ
, установленной на значениеUTC
, этот фрагмент кода будет работать. - person Omnifarious   schedule 13.01.2011