2009-10-14 16 views

Odpowiedz

13

nie sądzę jesteś przypuszczać, aby: „Nie rzucać wskaźnik do FILETIME strukturze albo ULARGE_INTEGER* lub __int64* wartość, ponieważ może to spowodować błędy wyrównania w 64-bitowym systemie Windows.”

Source.

Jeśli naprawdę chciał to byłoby coś takiego:

__int64 to_int64(FILETIME ft) 
{ 
    return static_cast<__int64>(ft.dwHighDateTime) << 32 | ft.dwLowDateTime; 
} 

FILETIME ft = // ... 
__int64 t = to_int64(ft); 

ale coś takiego:

FILETIME ft = // ... 
__int64 t = *reinterpet_cast<__int64*>(&ft); 

jest złe.

+0

byłem w procesie edycji :) – GManNickG

+1

Jak o memcpy (<__int64>, & FILETIME, 8); ? Czy to jest bezpieczne? – akif

+1

Chciałbym znaleźć 'memcpy' trudniejsze do zrozumienia, ale jestem pewien, że to by działało. Kompilator prawdopodobnie zoptymalizuje zmianę i/lub lepiej. – GManNickG

4

Spróbuj

(__int64(filetime.dwHighDateTime)<<32) | __int64(filetime.dwLowDateTime) 
1

Oczywiście można po prostu przejść w __int64 odlewano do FILETIME następująco * (*) FILETIME & int64Val. To zadziała dobrze w Visual C++.

tj

__int64 createTime = 0; 
__int64 accessTime = 0; 
__int64 writeTime = 0; 
GetFileTime(hFile, *(FILETIME*)&createTime, *(FILETIME*)&accessTime, *(FILETIME*)&writeTime); 
7

Nie ma potrzeby, aby powrócić do tajemniczych konstrukcji wykorzystujących bitowym OR-tych. Windows API ma wszystko, czego potrzebujesz, aby to zrobić.

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

Lub jeśli chcesz bezpośrednio przejść do __int64.

__int64 convert_to_int64(const FILETIME & ac_FileTime) 
{ 
    return static_cast<__int64> (convert(ac_FileTime)) ; 
} 
1

możesz wypróbować poniższy kod. kod jest od projektu chromu

template <class Dest, class Source> 
 
inline Dest bit_cast(const Source& source) { 
 
\t Dest dest; 
 
\t memcpy(&dest, &source, sizeof(dest)); 
 
\t return dest; 
 
} 
 

 
//FILETIME to __int64 
 

 
__int64 FileTimeToMicroseconds(const FILETIME& ft) { 
 
\t return bit_cast<__int64, FILETIME>(ft)/10; 
 
} 
 

 
void MicrosecondsToFileTime(__int64 us, FILETIME* ft) { 
 
\t *ft = bit_cast<FILETIME, __int64>(us * 10); 
 
} 
 

 
int _tmain(int argc, _TCHAR* argv[]) 
 
{ 
 
\t __int64 nTmpUint64 = 13060762249644841; 
 

 
\t time_t unixtime; 
 
\t FILETIME nTmpFileTm; 
 
\t MicrosecondsToFileTime(nTmpUint64,&nTmpFileTm); 
 

 
\t return 0; 
 
}

Powiązane problemy