FindFirstFileTransactedA 函数 (winbase.h)

[Microsoft 强烈建议开发人员使用替代方法来实现应用程序的需求。 TxF 致力于实现的许多方案都可以通过更简单、更易用的技术来实现。 此外,TxF 在 Microsoft Windows 的将来版本中可能不可用。 有关详细信息,以及 TxF 的替代方法,请参阅事务性 NTFS 的替代方法。]

以事务处理操作的形式在目录中搜索名称与特定名称匹配的文件或子目录。

此函数是 FindFirstFileEx 函数的事务处理形式。

有关此函数的最基本版本,请参阅 FindFirstFile

语法

HANDLE FindFirstFileTransactedA(
  [in]  LPCSTR             lpFileName,
  [in]  FINDEX_INFO_LEVELS fInfoLevelId,
  [out] LPVOID             lpFindFileData,
  [in]  FINDEX_SEARCH_OPS  fSearchOp,
        LPVOID             lpSearchFilter,
  [in]  DWORD              dwAdditionalFlags,
  [in]  HANDLE             hTransaction
);

参数

[in] lpFileName

目录或路径以及文件名。 文件名可以包含通配符,例如星号 (*) 或问号 (?) 。

此参数不应为 NULL、无效字符串 (例如,空字符串或缺少终止 null 字符的字符串) ,或以尾随反斜杠 (\) 结尾。

如果字符串以通配符、句点 (.) 或目录名称结尾,则用户必须有权访问路径上的根目录和所有子目录。

默认情况下,名称限制为MAX_PATH个字符。 若要将此限制扩展到 32,767 个宽字符,请在路径前面添加“\?\”。 有关详细信息,请参阅命名文件、路径和命名空间

提示

从 Windows 10 版本 1607 开始,可以选择删除MAX_PATH限制,而无需在前面添加“\\?\”。 有关详细信息,请参阅 命名文件、路径和命名空间 的“最大路径长度限制”部分。

文件必须驻留在本地计算机上;否则,函数将失败,最后一个错误代码设置为 ERROR_TRANSACTIONS_UNSUPPORTED_REMOTE

[in] fInfoLevelId

返回的数据的信息级别。

此参数是 FINDEX_INFO_LEVELS 枚举值之一。

[out] lpFindFileData

指向 WIN32_FIND_DATA 结构的指针,该结构接收有关找到的文件或子目录的信息。

[in] fSearchOp

要执行的筛选类型与通配符匹配不同。

此参数是 FINDEX_SEARCH_OPS 枚举值之一。

lpSearchFilter

如果指定的 fSearchOp 需要结构化搜索信息,则为指向搜索条件的指针。

目前,任何受支持的 fSearchOp 值都不需要扩展搜索信息。 因此,此指针必须为 NULL

[in] dwAdditionalFlags

指定控制搜索的其他标志。

含义
FIND_FIRST_EX_CASE_SENSITIVE
1
搜索区分大小写。

[in] hTransaction

事务的句柄。 此句柄由 CreateTransaction 函数返回。

返回值

如果函数成功,则返回值是后续调用 FindNextFileFindClose 中使用的搜索句柄, lpFindFileData 参数包含有关找到的第一个文件或目录的信息。

如果函数失败或无法从 lpFileName 参数中的搜索字符串中找到文件,则返回值为 INVALID_HANDLE_VALUE并且 lpFindFileData 的内容不确定。 若要获得更多的错误信息,请调用 GetLastError 函数。

注解

FindFirstFileTransacted 函数会打开一个搜索句柄,并返回有关文件系统使用与指定模式匹配的名称查找的第一个文件的信息。 给定相同的文件名字符串模式时,这可能是也可能不是目录列表应用程序 ((例如 dir 命令) )中显示的第一个文件或目录。 这是因为 FindFirstFileTransacted 不对搜索结果进行排序。 有关其他信息,请参阅 FindNextFile

以下列表标识了一些其他搜索特征:

  • 搜索严格针对文件名执行,而不是对日期或文件类型等任何属性执行。
  • 搜索包括长文件名和短文件名。
  • 尝试使用尾随反斜杠打开搜索始终失败。
  • lpFileName 参数传递无效的字符串、NULL 或空字符串不是此函数的有效用法。 在这种情况下,结果未定义。
注意 在极少数情况下,调用此函数时,NTFS 文件系统上的文件信息可能不是最新的。 若要确保获取当前文件信息,请调用 GetFileInformationByHandle 函数。
 
如果基础文件系统不支持指定的筛选类型(除目录筛选之外), FindFirstFileTransacted 将失败并 ERROR_NOT_SUPPORTED错误。 应用程序必须使用 FINDEX_SEARCH_OPS 类型 FileExSearchNameMatch 并执行自己的筛选。

建立搜索句柄后,在 FindNextFile 函数中使用它来搜索与正在执行的相同筛选相同的模式匹配的其他文件。 当不需要搜索句柄时,应使用 FindClose 函数将其关闭。

如前所述,不能在 FindFirstFileTransactedlpFileName 输入字符串中使用尾随反斜杠 (\) ,因此搜索根目录的方式可能并不明显。 如果要查看文件或获取根目录的属性,将应用以下选项:

  • 若要检查根目录中的文件,可以使用“C:\*”,并使用 FindNextFile 单步执行目录。
  • 若要获取根目录的属性,请使用 GetFileAttributes 函数。
注意 附加字符串“\\?\”不允许访问根目录。
 

在网络共享上,可以使用以下形式的 lpFileName :“\\server\service*”。 但是,不能使用指向共享本身的 lpFileName ;例如,“\\server\service”无效。

若要检查不是根目录的目录,请使用该目录的路径,而不使用尾随反斜杠。 例如,“C:\Windows”的参数返回有关目录“C:\Windows”的信息,而不是有关“C:\Windows”中的目录或文件的信息。 若要检查“C:\Windows”中的文件和目录,请使用“C:\Windows\*”的 lpFileName

请注意,在查询结果和处理信息的时间之间,其他线程或进程可能会创建或删除具有此名称的文件。 如果这是应用程序的潜在问题,一种可能的解决方案是将 CreateFile 函数与 CREATE_NEW (如果文件) 存在,则 OPEN_EXISTING (如果) 不存在文件,则会失败。

如果要编写 32 位应用程序以列出目录中的所有文件,并且应用程序可能在 64 位计算机上运行,则应在调用 FindFirstFileTransacted 之前调用 Wow64DisableWow64FsRedirection,并在上次调用 FindNextFile 之后调用 Wow64RevertWow64FsRedirection。 有关详细信息,请参阅 文件系统重定向程序

如果路径指向符号链接,WIN32_FIND_DATA 缓冲区包含有关符号链接而不是目标的信息。

在 Windows 8 和 Windows Server 2012 中,此函数由以下技术支持。

技术 支持
服务器消息块 (SMB) 3.0 协议
SMB 3.0 透明故障转移 (TFO)
具有横向扩展文件共享的 SMB 3.0 (SO)
群集共享卷文件系统 (CSV)
弹性文件系统 (ReFS)
 

SMB 3.0 不支持 TxF。

注意

winbase.h 标头将 FindFirstFileTransacted 定义为别名,该别名根据 UNICODE 预处理器常量的定义自动选择此函数的 ANSI 或 Unicode 版本。 将非特定编码别名的使用与非非特定编码的代码混合使用可能会导致不匹配,从而导致编译或运行时错误。 有关详细信息,请参阅 函数原型的约定

要求

要求
最低受支持的客户端 Windows Vista [仅限桌面应用]
最低受支持的服务器 Windows Server 2008 [仅限桌面应用]
目标平台 Windows
标头 winbase.h (包括 Windows.h)
Library Kernel32.lib
DLL Kernel32.dll

另请参阅

文件管理函数

FindClose

FindNextFile

GetFileAttributes

SetFileAttributes

符号链接

事务性 NTFS

WIN32_FIND_DATA