#[non_exhaustive]pub enum ErrorKind {
Show 40 variants
NotFound,
PermissionDenied,
ConnectionRefused,
ConnectionReset,
HostUnreachable,
NetworkUnreachable,
ConnectionAborted,
NotConnected,
AddrInUse,
AddrNotAvailable,
NetworkDown,
BrokenPipe,
AlreadyExists,
WouldBlock,
NotADirectory,
IsADirectory,
DirectoryNotEmpty,
ReadOnlyFilesystem,
FilesystemLoop,
StaleNetworkFileHandle,
InvalidInput,
InvalidData,
TimedOut,
WriteZero,
StorageFull,
NotSeekable,
FilesystemQuotaExceeded,
FileTooLarge,
ResourceBusy,
ExecutableFileBusy,
Deadlock,
CrossesDevices,
TooManyLinks,
InvalidFilename,
ArgumentListTooLong,
Interrupted,
Unsupported,
UnexpectedEof,
OutOfMemory,
Other,
}
Expand description
一个列表,指定 I/O 错误的常规类别。
此列表旨在随着时间的增长而增长,不建议对其进行详尽的匹配。
与 io::Error
类型一起使用。
在 ErrorKind
上处理错误和匹配
在应用程序代码中,使用 match
作为您期望的 ErrorKind
值; 使用 _
匹配 “所有其他错误”。
在想要验证测试不会返回任何已知的不正确错误类型的全面而彻底的测试中,您可能需要将当前完整的错误列表从此处剪切并粘贴到您的测试代码中,然后将 _
匹配为正确的情况。
这似乎违反直觉,但它会使您的测试更加健壮。
特别是,如果您想验证您的代码确实产生了无法识别的错误类型,那么可靠的解决方案是检查所有已识别的错误类型并在这些情况下失败。
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
NotFound
找不到实体,通常是文件。
PermissionDenied
该操作缺少完成操作所需的权限。
ConnectionRefused
远程服务器拒绝了连接。
ConnectionReset
连接已由远程服务器重置。
HostUnreachable
io_error_more
#86442)远程主机不可访问。
NetworkUnreachable
io_error_more
#86442)无法访问包含远程主机的网络。
ConnectionAborted
(terminated) 连接被远程服务器中止。
NotConnected
网络操作失败,因为尚未连接。
AddrInUse
无法绑定套接字地址,因为该地址已在其他地方使用。
AddrNotAvailable
请求了不存在的接口,或者请求的地址不是本地的。
NetworkDown
io_error_more
#86442)系统的网络已关闭。
BrokenPipe
操作失败,因为管道已关闭。
AlreadyExists
一个实体已经存在,通常是一个文件。
WouldBlock
该操作需要阻止才能完成,但是请求阻止操作不会发生。
NotADirectory
io_error_more
#86442)出乎意料的是,文件系统对象不是目录。
例如,指定了一个文件系统路径,其中一个中间目录组件实际上是一个普通文件。
IsADirectory
io_error_more
#86442)出乎意料的是,文件系统对象是一个目录。
当需要一个非目录时指定了一个目录。
DirectoryNotEmpty
io_error_more
#86442)在需要空目录的地方指定了一个非空目录。
ReadOnlyFilesystem
io_error_more
#86442)文件系统或存储介质是只读的,但尝试了写入操作。
FilesystemLoop
io_error_more
#86442)在文件系统或 IO 子系统中循环; 通常,太多级别的符号链接。
有一个循环 (或过长的链) 解析文件系统对象或文件 IO 对象。
在 Unix 上,这通常是符号链接循环的结果; 或者,超过系统特定的符号链接遍历深度限制。
StaleNetworkFileHandle
io_error_more
#86442)陈旧的网络文件句柄。
对于某些网络文件系统,尤其是 NFS,打开的文件 (或目录) 可能会因网络或服务器问题而失效。
InvalidInput
参数不正确。
InvalidData
遇到对该操作无效的数据。
与 InvalidInput
不同,这通常意味着操作参数有效,但是该错误是由格式错误的输入数据引起的。
例如,如果文件的内容无效 UTF-8,则将文件读入字符串的函数将出现 InvalidData
错误。
TimedOut
I/O 操作的超时已到期,导致其被取消。
WriteZero
StorageFull
io_error_more
#86442)底层存储 (通常是文件系统) 已满。
这不包括超出配额的错误。
NotSeekable
io_error_more
#86442)Seek 在不可搜索的文件上。
尝试在不适合搜索的打开文件句柄上进行搜索 - 例如,在 Unix 上,使用 File::open
打开的命名管道。
FilesystemQuotaExceeded
io_error_more
#86442)超出了文件系统配额。
FileTooLarge
io_error_more
#86442)文件大于允许或支持。
这可能源于底层文件系统或文件访问 API 的硬限制,或源于管理强加的资源限制。 简单的磁盘已满,超出配额,都有自己的错误。
ResourceBusy
io_error_more
#86442)资源繁忙。
ExecutableFileBusy
io_error_more
#86442)可执行文件正忙。
试图写入一个文件,该文件也用作正在运行的程序。 (并非所有操作系统都检测到这种情况。)
Deadlock
io_error_more
#86442)死锁 (avoided)。
文件锁定操作会导致死锁。 这种情况通常是在尽力而为的基础上检测到的。
CrossesDevices
io_error_more
#86442)跨设备或跨文件系统 (hard) 链接或重命名。
TooManyLinks
io_error_more
#86442)太多 (hard) 链接到同一个文件系统对象。
文件系统不支持对同一个文件建立如此多的硬链接。
InvalidFilename
io_error_more
#86442)文件名无效。
如果超出文件名长度限制,也会导致此错误。
ArgumentListTooLong
io_error_more
#86442)程序参数列表太长。
尝试运行外部程序时,会超出系统或进程对参数大小的限制。
Interrupted
该操作被中断。
通常可以重试中断的操作。
Unsupported
此平台不支持此操作。
这意味着操作永远不会成功。
UnexpectedEof
由于过早到达 “文件结尾” 而无法完成操作时,返回错误。
通常,这意味着操作只有在读取特定数量的字节后才能成功,但是只能读取较少的字节。
OutOfMemory
操作无法完成,因为它未能分配足够的内存。