Posso usar o CreateFile, mas forçar o identificador em um std :: ofstream?

Existe alguma maneira de tirar proveito dos sinalizadores de criação de arquivo na API do Win32, como FILE_FLAG_DELETE_ON_CLOSE ou FILE_FLAG_WRITE_THROUGH conforme descrito aqui http://msdn.microsoft.com/en-us/library/aa363858(VS.85).aspx , mas então forçar esse identificador em um std :: ofstream?

A interface para o ofstream é obviamente independente da plataforma; Eu gostaria de forçar algumas configurações dependentes de plataforma em ‘sob o capô’, por assim dizer.

É possível append um C ++ std::ofstream a um identificador de arquivo do Windows. O código a seguir funciona no VS2008:

 HANDLE file_handle = CreateFile( file_name, GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL); if (file_handle != INVALID_HANDLE_VALUE) { int file_descriptor = _open_osfhandle((intptr_t)file_handle, 0); if (file_descriptor != -1) { FILE* file = _fdopen(file_descriptor, "w"); if (file != NULL) { std::ofstream stream(file); stream << "Hello World\n"; // Closes stream, file, file_descriptor, and file_handle. stream.close(); file = NULL; file_descriptor = -1; file_handle = INVALID_HANDLE_VALUE; } } 

Isso funciona com FILE_FLAG_DELETE_ON_CLOSE , mas FILE_FLAG_WRITE_THROUGH pode não ter o efeito desejado, como dados serão armazenados em buffer pelo object std::ofstream e não devem ser gravados diretamente no disco. Quaisquer dados no buffer serão liberados para o sistema operacional quando stream.close() for chamado, no entanto.

Alguns desses sinalizadores também estão disponíveis ao usar _fsopen / fopen:

 FILE* pLockFile = _fsopen(tmpfilename.c_str(), "w", _SH_DENYWR ); if (pLockFile!=NULL { // Write lock aquired ofstream fs(pLockFile); } 

Aqui nós abrimos o arquivo assim quando fazendo um flush, então ele grava (E ele é deletado quando fechado):

 FILE* pCommitFile = fopen(tmpfilename.c_str(), "wcD"); if (pCommitFile!=NULL) { // Commits when doing flush ofstream fs(pCommitFile); }