GetFinalPathNameByHandleW 関数 (fileapi.h)
指定したファイルの最終的なパスを取得します。
ファイル名とパス名の詳細については、「ファイルの名前付け」を参照してください。
構文
DWORD GetFinalPathNameByHandleW(
[in] HANDLE hFile,
[out] LPWSTR lpszFilePath,
[in] DWORD cchFilePath,
[in] DWORD dwFlags
);
パラメーター
[in] hFile
ファイルまたはディレクトリへのハンドル。
[out] lpszFilePath
hFileのパス
[in] cchFilePath
lpszFilePathのサイズ (TCHAR単位)。 この値には、NULL 終了文字を含める必要があります。
[in] dwFlags
返される結果の型。 このパラメーターには、次のいずれかの値を指定できます。
価値 | 意味 |
---|---|
|
正規化されたドライブ名を返します。 これが既定値です。 |
|
開いているファイル名 (正規化されていない) を返します。 |
このパラメーターには、次のいずれかの値を含めることもできます。
価値 | 意味 |
---|---|
|
ドライブ文字を含むパスを返します。 これが既定値です。 |
|
ドライブ名ではなく、ボリューム GUID パスを含むパスを返します。 |
|
ドライブ情報のないパスを返します。 |
|
NT デバイス オブジェクト のパスを返します。 |
戻り値
関数が成功した場合、戻り値は、lpszFilePathが受け取った文字列の長さ (TCHAR単位) です。 この値には、終端の null 文字のサイズは含まれません。
lpszFilePath
その他の理由で関数が失敗した場合、戻り値は 0 になります。 拡張エラー情報を取得するには、GetLastError
リターン コード | 形容 |
---|---|
|
ドライブ文字を検索していて、存在しない場合に返すことができます。 たとえば、現在マウントされていないドライブでハンドルが開かれた場合や、ボリュームを作成してドライブ文字を割り当てない場合などです。 ボリュームにドライブ文字がない場合は、GUID パス この戻り値は、ネットワーク共有の GUID パス |
|
操作を完了するためのメモリが不足しています。 |
|
dwFlagsに無効なフラグが指定されました。 |
備考
サーバー メッセージ ブロック (SMB) プロトコルは、正規化されたパスのクエリをサポートしていません。 したがって、SMB を使用して開かれたファイルのハンドルを渡し、FILE_NAME_NORMALIZED フラグを使用してこの関数を呼び出すと、関数はパスをそのコンポーネントに分割し、それらの各コンポーネントの正規化された名前を順番に照会しようとします。 ユーザーがこれらのコンポーネントのいずれかに対するアクセス許可を持たない場合、関数呼び出しはERROR_ACCESS_DENIEDで失敗します。
最後のパスは、パスが完全に解決されたときに返されるパスです。 たとえば、"D:\yourdir" を指す "C:\tmp\mydir" という名前のシンボリック リンクの場合、最終的なパスは "D:\yourdir" になります。
VOLUME_NAME_DOSを使用する場合、この関数によって返される文字列は "\\?\" 構文を使用します。 詳細については、「CreateFile
VOLUME_NAME_GUIDを使用する場合、返されるパスは、"\\?\Volume{xxxxxxxx-xxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx}\" のような形式のボリューム GUID パスで始まります。
VOLUME_NAME_NTを使用する場合、返されるパスは NT デバイス オブジェクト用であり、"\Device\HarddiskVolume1\" などのデバイス名で始まります。 この種類のパスは、相対パスに似ているため、Windows プログラムで直接使用することはできません。
一部のサード パーティ製ドライバーは、マウント マネージャーを使用せずにドライブ文字またはマウント ポイントを作成できます。 マウント マネージャーを使用してドライブを作成しなかった場合、VOLUME_NAME_DOS または VOLUME_NAME_GUID は成功しません。VOLUME_NAME_NT のみが使用できます。 ボリューム デバイス パスのドライブ文字を確認するには、一致するデバイス名が見つかるまで、すべてのドライブ文字で QueryDosDevice 関数を使用します。
Windows 8 および Windows Server 2012 では、この関数は次のテクノロジでサポートされています。
テクノロジー | サポート |
---|---|
サーバー メッセージ ブロック (SMB) 3.0 プロトコル | はい |
SMB 3.0 透過的フェールオーバー (TFO) | はい |
SMB 3.0 とスケールアウト ファイル共有 (SO) | はい |
クラスター共有ボリューム ファイル システム (CsvFS) | はい |
回復性のあるファイル システム (ReFS) | はい |
例
次の例では、GetFinalPathNameByHandle 関数の使用を示します。
#include <windows.h>
#include <tchar.h>
#include <stdio.h>
#define BUFSIZE MAX_PATH
void __cdecl _tmain(int argc, TCHAR *argv[])
{
TCHAR Path[BUFSIZE];
HANDLE hFile;
DWORD dwRet;
printf("\n");
if( argc != 2 )
{
printf("ERROR:\tIncorrect number of arguments\n\n");
printf("%s <file_name>\n", argv[0]);
return;
}
hFile = CreateFile(argv[1], // file to open
GENERIC_READ, // open for reading
FILE_SHARE_READ, // share for reading
NULL, // default security
OPEN_EXISTING, // existing file only
FILE_ATTRIBUTE_NORMAL, // normal file
NULL); // no attr. template
if( hFile == INVALID_HANDLE_VALUE)
{
printf("Could not open file (error %d\n)", GetLastError());
return;
}
dwRet = GetFinalPathNameByHandle( hFile, Path, BUFSIZE, VOLUME_NAME_NT );
if(dwRet < BUFSIZE)
{
_tprintf(TEXT("\nThe final path is: %s\n"), Path);
}
else printf("\nThe required buffer size is %d.\n", dwRet);
CloseHandle(hFile);
}
手記
fileapi.h ヘッダーは、Unicode プリプロセッサ定数の定義に基づいて、この関数の ANSI または Unicode バージョンを自動的に選択するエイリアスとして GetFinalPathNameByHandle を定義します。 エンコードに依存しないエイリアスをエンコードに依存しないコードと組み合わせて使用すると、コンパイルエラーやランタイム エラーが発生する不一致が発生する可能性があります。 詳細については、「関数プロトタイプの 規則」を参照してください。
必要条件
要件 | 価値 |
---|---|
サポートされる最小クライアント | Windows Vista [デスクトップ アプリ |UWP アプリ] |
サポートされる最小サーバー | Windows Server 2008 [デスクトップ アプリ |UWP アプリ] |
ターゲット プラットフォーム の |
ウィンドウズ |
ヘッダー | fileapi.h (Windows.h を含む) |
ライブラリ | Kernel32.lib |
DLL | Kernel32.dll |