登录
首页 >  Golang >  Go问答

调试无法识别的内存位置

来源:stackoverflow

时间:2024-03-18 20:48:29 381浏览 收藏

在 Windows 10 上运行 Go 程序时,用户遇到了“无效内存地址或 nil 指针解引用”的错误。通过查看堆栈跟踪,可以确定错误发生在 scantoencrypt 函数中,该函数负责扫描文件以进行加密。 尽管用户认为已经处理了错误,但事实并非如此。问题在于 return 文件的错误 stat, _ := os.Stat(path) 未被正确处理。建议处理此错误,例如,如果错误不为空,则返回错误,或者打印错误消息。

问题内容

我正在构建一个简单的 go 应用程序,但是当我在 windows 10 上执行我的程序时,出现以下错误: 更新:现在包含完整的堆栈跟踪。

panic: runtime error: invalid memory address or nil pointer dereference
[signal 0xc0000005 code=0x0 addr=0x18 pc=0x478edd]

goroutine 1 [running]:
github.com/uppercenter/amalthea/src/files.(*files).scantoencrypt.func1(0xc000162aa0, 0x4c, 0x4caaa0, 0xc000167b20, 0x0, 0x0, 0x4c, 0x2)
        /home/uppercenter/amalthea/src/files/files.go:48 +0x13d
path/filepath.walk(0xc000162aa0, 0x4c, 0x4caaa0, 0xc000167b20, 0xc000221d18, 0x0, 0x0)
        /usr/lib/go/src/path/filepath/path.go:360 +0x443
path/filepath.walk(0xc000560e10, 0x30, 0x4caaa0, 0xc000167500, 0xc000221d18, 0x0, 0x0)
        /usr/lib/go/src/path/filepath/path.go:384 +0x31a
path/filepath.walk(0xc0001719b0, 0x24, 0x4caaa0, 0xc000191650, 0xc000221d18, 0x0, 0x0)
        /usr/lib/go/src/path/filepath/path.go:384 +0x31a
path/filepath.walk(0xc000011720, 0x1a, 0x4caaa0, 0xc000180000, 0xc000221d18, 0x0, 0x0)
        /usr/lib/go/src/path/filepath/path.go:384 +0x31a
path/filepath.walk(0xc0000116a0, 0x14, 0x4caaa0, 0xc000175dc0, 0xc000221d18, 0x0, 0x0)
        /usr/lib/go/src/path/filepath/path.go:384 +0x31a
path/filepath.walk(0xc00000acc0, 0xc, 0x4caaa0, 0xc000174af0, 0xc000221d18, 0x0, 0x0)
        /usr/lib/go/src/path/filepath/path.go:384 +0x31a
path/filepath.walk(0x4a4206, 0x9, 0x4caaa0, 0xc00010a000, 0xc000221d18, 0x0, 0x457a58)
        /usr/lib/go/src/path/filepath/path.go:384 +0x31a
path/filepath.walk(0x4a4206, 0x9, 0xc000077d18, 0x280, 0x26c)
        /usr/lib/go/src/path/filepath/path.go:406 +0x10c
github.com/uppercenter/amalthea/src/files.(*files).scantoencrypt(0xc000077f48, 0xc000006018, 0xc000077df8, 0x1, 0x1, 0x26c)
        /home/uppercenter/amalthea/src/files/files.go:40 +0x86
main.main()
        /home/uppercenter/amalthea/main.go:63 +0x193

我了解到发生这种情况是因为 scantoencrypt 中存在未处理的错误。

这是 scantoencrypt 函数:

// ScanToEncrypt scans all valid files to encrypt
func (f *Files) ScanToEncrypt() ([]string, error) {
    // Store encryptable files as array.
    var files []string
    // Begin "walking" from `rootDir` to get all available folders & subfolders
    err := filepath.Walk(f.rootDir, func(path string, info os.FileInfo, err error) error {
        // Returns info describing a named file.
        stat, _ := os.Stat(path)
        // HasSuffix looks for encoded files.
        if !strings.HasSuffix(path, ".AmaltheaEnc") {
            if !stat.IsDir() {
                // Checks the file is below maximum file size in bytes defined by `size`
                if stat.Size() <= int64(f.size) {
                    for _, ext := range f.exts {
                        if strings.Contains(path, "."+ext) {
                            // Append file & file path to `files`
                            files = append(files, path)
                            break
                        }
                    }
                }
            }
        }
        return nil
    })
    // Return `files` array to use for encryption
    return files, err
}

我以为我正在处理 return 文件的错误,err 但我想不是。 谁能帮助我更好地理解我应该在这里做什么?


解决方案


不要在这里丢弃潜在的错误 stat, _ := os.Stat(path)。您应该处理它,例如,如果它不为空,则返回错误,或者打印错误消息

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《调试无法识别的内存位置》文章吧,也可关注golang学习网公众号了解相关技术文章。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>