我使用的代码类似于下面的代码。如果目录被阻止,则重命名可能会失败,因为某些应用程序中的文件已打开。
err := os.Rename("C:/temp/inUse", "c:/temp/Renamed")
if err != nil {
fmt.Println(err)
...
}
当我检查err
此内容时,我能够检测到这一事实:
重命名C:/ temp / inUse c:/ temp / Renamed:Der Prozess kann nicht auf die Datei zugreifen,da sie von einem anderen Prozess verwendet wird。
(转换为“进程无法访问该文件,因为它由不同的进程使用”) 但是此消息因操作系统语言而异。
是否可以通过唯一的“错误代码”检测问题?我不介意该解决方案是否特定于Windows,并且不适用于Go支持的其他操作系统。
理想情况下,我可以做if err.Err == 32 { fmt.Println( "Your directory is in use please ...
答案 0 :(得分:4)
os.Rename
返回的错误类型为*os.LinkError
,可让您从操作系统中访问基础错误。您应该可以使用它来区分您遇到的特定错误。
您需要先将错误转换为* os.LinkError。
例如,尝试将文件夹(/Users/t/pprof
)重命名为另一个写保护的名称(/Users/t/pprof2
):
func TestRename(t *testing.T) {
err := os.Rename("/Users/t/pprof", "/Users/t/pprof2")
if err != nil {
e := err.(*os.LinkError)
t.Logf("Op: ", e.Op)
t.Logf("Old: ", e.Old)
t.Logf("New: ", e.New)
t.Logf("Err: ", e.Err)
}
}
提供以下输出:
Op: %!(EXTRA string=rename)
Old: %!(EXTRA string=/Users/t/pprof)
New: %!(EXTRA string=/Users/t/pprof2)
Err: %!(EXTRA syscall.Errno=operation not permitted)
操作系统错误代码可以作为Err
成员访问,但会根据您运行的操作系统而有所不同。
Err
成员的类型为syscall.Errno
。要进一步检查实际错误,您需要先将其转换为该类型:
oserr := e.Err.(syscall.Errno)
现在可以将oserr
与syscall
包中声明的Errno
值进行比较。如果您在该页面上搜索ENOENT
,您就会找到它们。
例如,您可以通过执行以下操作来检查您的特定错误:
switch oserr {
case syscall.ENOENT:
// Handle this error
default:
// Handle other errors
}
}
通常,在调试这些问题时使用fmt.Printf非常方便。在上面的例子中:
fmt.Println(err)
打印
rename /Users/t/pprof /Users/t/pprof2: operation not permitted
其中-作为
fmt.Printf("%#v\n", err)
打印
&os.LinkError{Op:"rename", Old:"/Users/t/pprof", New:"/Users/t/pprof2", Err:0x1}
详细说明实际错误,而不只是字符串表示。
答案 1 :(得分:1)
从Go 1.13开始,如果您只想检查基础错误是否为特定类型,可以执行以下操作:
std::remove
您可以在the official Golang blog的Go 1.13中阅读有关错误处理的更多信息。