Как правильно преобразовать структуру FILETIME
в __int64
? Не могли бы вы рассказать мне?
FILETIME в __int64
Ответы (6)
Я не думаю, что вы должны: «Не приводить указатель на структуру FILETIME
к значению ULARGE_INTEGER*
или __int64*
, потому что это может вызвать ошибки выравнивания в 64-разрядной Windows».
Если бы вы действительно хотели, это было бы что-то вроде:
__int64 to_int64(FILETIME ft)
{
return static_cast<__int64>(ft.dwHighDateTime) << 32 | ft.dwLowDateTime;
}
FILETIME ft = // ...
__int64 t = to_int64(ft);
Но что-то вроде:
FILETIME ft = // ...
__int64 t = *reinterpet_cast<__int64*>(&ft);
Плохо.
memcpy
сложнее понять, но я уверен, что это сработает. Компилятор, вероятно, может оптимизировать сдвиг или лучше.
- person GManNickG; 14.10.2009
Нет необходимости возвращаться к загадочным конструкциям с использованием побитового ИЛИ. В Windows API есть все необходимое для этого.
unsigned __int64 convert( const FILETIME & ac_FileTime )
{
ULARGE_INTEGER lv_Large ;
lv_Large.LowPart = ac_FileTime.dwLowDateTime ;
lv_Large.HighPart = ac_FileTime.dwHighDateTime ;
return lv_Large.QuadPart ;
}
Или, если вы хотите напрямую перейти к __int64.
__int64 convert_to_int64( const FILETIME & ac_FileTime )
{
return static_cast< __int64 > ( convert( ac_FileTime ) ) ;
}
ULARGEINTEGER{ ft.dwLowDateTime, ft.dwHighDateTime }.QuadPart
. Возможно, не более читабельно, однако вам не нужны дополнительные функции/макросы.
- person klaus triendl; 08.11.2018
Пытаться
(__int64(filetime.dwHighDateTime)<<32) | __int64(filetime.dwLowDateTime)
Конечно, вы можете просто передать __int64, приведенный к файловому времени, следующим образом *(FILETIME*)&int64Val. Это будет нормально работать под Visual C++.
ie
__int64 createTime = 0;
__int64 accessTime = 0;
__int64 writeTime = 0;
GetFileTime( hFile, *(FILETIME*)&createTime, *(FILETIME*)&accessTime, *(FILETIME*)&writeTime );
вы можете попробовать следующий код. код из проекта хром
template <class Dest, class Source>
inline Dest bit_cast(const Source& source) {
Dest dest;
memcpy(&dest, &source, sizeof(dest));
return dest;
}
//FILETIME to __int64
__int64 FileTimeToMicroseconds(const FILETIME& ft) {
return bit_cast<__int64, FILETIME>(ft) / 10;
}
void MicrosecondsToFileTime(__int64 us, FILETIME* ft) {
*ft = bit_cast<FILETIME, __int64>(us * 10);
}
int _tmain(int argc, _TCHAR* argv[])
{
__int64 nTmpUint64 = 13060762249644841;
time_t unixtime;
FILETIME nTmpFileTm;
MicrosecondsToFileTime(nTmpUint64,&nTmpFileTm);
return 0;
}
У меня была точно такая же проблема, погуглил и пришел сюда. Но я также нашел полезную страницу поддержки Microsoft по адресу
https://support.microsoft.com/en-gb/help/188768/info-working-with-the-filetime-structure
В нем говорится:
Выполнение арифметических операций с временем файла
Часто бывает необходимо выполнить простую арифметику времени файла. Например, вам может понадобиться узнать, когда файлу исполнилось 30 дней. Чтобы выполнить арифметические действия над временем файла, необходимо преобразовать FILETIME в четверное слово (64-разрядное целое число), выполнить арифметические действия, а затем преобразовать результат обратно в FILETIME.
Предполагая, что ft является структурой FILETIME, содержащей время создания файла, следующий пример кода добавляет ко времени 30 дней:
ULONGLONG qwResult;
// Copy the time into a quadword.
qwResult = (((ULONGLONG) ft.dwHighDateTime) << 32) + ft.dwLowDateTime;
// Add 30 days.
qwResult += 30 * _DAY;
// Copy the result back into the FILETIME structure.
ft.dwLowDateTime = (DWORD) (qwResult & 0xFFFFFFFF );
ft.dwHighDateTime = (DWORD) (qwResult >> 32 );
Изменить: я понимаю, что это просто подтверждает некоторые другие ответы, но я подумал, что стоит добавить для уточнения.