CreateHardLinkTransactedA 関数 (winbase.h)
[Microsoft では、開発者がアプリケーションのニーズを達成するために代替手段を利用することを強くお勧めします。 TxF が開発された多くのシナリオは、よりシンプルで利用しやすい手法で実現できます。 また、将来のバージョンの Microsoft Windows では TxF を使用できない場合があります。 詳細、および TxF の代替手段については、「トランザクション NTFS の使用の代替手段」を参照してください。]
トランザクション操作として、既存のファイルと新規のファイルの間にハード リンクを確立します。 この関数は NTFS ファイル システムでのみサポートされ、ディレクトリではなくファイルに対してのみサポートされます。
構文
BOOL CreateHardLinkTransactedA(
[in] LPCSTR lpFileName,
[in] LPCSTR lpExistingFileName,
LPSECURITY_ATTRIBUTES lpSecurityAttributes,
[in] HANDLE hTransaction
);
パラメーター
[in] lpFileName
新しいファイルの名前。
このパラメーターは、ディレクトリの名前を指定できません。
[in] lpExistingFileName
既存のファイルの名前。
このパラメーターは、ディレクトリの名前を指定できません。
lpSecurityAttributes
予約; は NULL である必要があります。
[in] hTransaction
トランザクションのハンドル。 このハンドルは、 CreateTransaction 関数によって返されます。
戻り値
関数が成功すると、戻り値は 0 以外になります。
関数が失敗した場合は、0 を返します。 詳細なエラー情報を得るには、GetLastError を呼び出します。
この関数で作成できるハード リンクの最大数は、ファイルあたり 1023 です。 ファイルに対して 1023 個を超えるリンクが作成されると、エラーが発生します。
ファイルはローカル コンピューター上に存在する必要があります。それ以外の場合、関数は失敗し、最後のエラー コードは ERROR_TRANSACTIONS_UNSUPPORTED_REMOTE に設定されます。
注釈
CreateFileTransacted または CreateHardLinkTransacted を使用して作成されたファイルのディレクトリ エントリは、関連付けられたファイルへのハード リンクです。 CreateHardLinkTransacted 関数を使用して作成された追加のハード リンクを使用すると、ファイルの複数のディレクトリ エントリ、つまり同じファイルへの複数のハード リンク (同じディレクトリ内の異なる名前、または異なるディレクトリ内の同じまたは異なる名前) を使用できます。 ただし、ファイルへのハード リンクはすべて同じボリューム上にある必要があります。
ハード リンクはファイルのディレクトリ エントリだけなので、アプリケーションがハード リンクを介してファイルを変更すると、そのファイルへの他のハード リンクを使用するすべてのアプリケーションで変更が表示されます。 また、ファイルが変更されると、すべてのディレクトリ エントリが更新されます。 たとえば、ファイル サイズが変更された場合、ファイルへのすべてのハード リンクに新しいファイル サイズが表示されます。
セキュリティ記述子は、ハード リンクが指すファイルに属しています。 リンク自体はディレクトリ エントリのみで、セキュリティ記述子はありません。 したがって、ハード リンクのセキュリティ記述子を変更すると、基になるファイルのセキュリティ記述子が変更され、ファイルを指すすべてのハード リンクで新しく指定されたアクセスが許可されます。 ハード リンクごとにファイルに異なるセキュリティ記述子を指定することはできません。
この関数は、 lpSecurityAttributes パラメーターにセキュリティ記述子情報が渡された場合でも、リンク先のファイルのセキュリティ記述子を変更しません。
DeleteFileTransacted を使用して、ハード リンクを削除します。 作成された順序に関係なく、任意の順序で削除できます。
CreateFileTransacted で指定されているフラグ、属性、アクセス、共有は、ファイルごとに動作します。 つまり、共有を許可しないファイルを開くと、別のアプリケーションはファイルへの新しいハード リンクを作成してファイルを共有できません。
NTFS ファイル システムでハード リンクを作成すると、ディレクトリ エントリ内のファイル属性情報が更新されるのは、ファイルが開かれている場合、または GetFileInformationByHandle が特定のファイルのハンドルを使用して呼び出されたときだけです。
シンボリック リンク: パスがシンボリック リンクを指している場合、関数はターゲットへのハード リンクを作成します。
Windows 8 と Windows Server 2012 では、この関数は、次のテクノロジによってサポートされています。
テクノロジ | サポートされています |
---|---|
サーバー メッセージ ブロック (SMB) 3.0 プロトコル | いいえ |
SMB 3.0 Transparent Failover (TFO) | いいえ |
スケールアウト ファイル共有 (SO) を使う SMB 3.0 | いいえ |
クラスターの共有ボリューム ファイル システム (CsvFS) | いいえ |
Resilient File System (ReFS) | いいえ |
SMB 3.0 では TxF がサポートされないことに注意してください。
注意
winbase.h ヘッダーは、CreateHardLinkTransacted をエイリアスとして定義し、UNICODE プリプロセッサ定数の定義に基づいて、この関数の ANSI または Unicode バージョンを自動的に選択します。 エンコードに依存しないエイリアスをエンコードニュートラルでないコードと組み合わせて使用すると、コンパイルまたはランタイム エラーが発生する不一致が発生する可能性があります。 詳細については、「 関数プロトタイプの規則」を参照してください。
要件
要件 | 値 |
---|---|
サポートされている最小のクライアント | Windows Vista [デスクトップ アプリのみ] |
サポートされている最小のサーバー | Windows Server 2008 [デスクトップ アプリのみ] |
対象プラットフォーム | Windows |
ヘッダー | winbase.h (Windows.h を含む) |
Library | Kernel32.lib |
[DLL] | Kernel32.dll |