- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
如何获取最后一个(理想情况下)go 例程(该应用程序有多个 go 例程)的堆栈跟踪,该例程发生 panic 并恢复并仅记录了一条不多的描述性错误消息?不知道哪个套路恢复了。另外,请记住我不会更改任何导入包的代码。这种 panic 发生在一些创建多个 go 例程的导入包中,因此我需要一种方法来获取最后恢复的例程的堆栈跟踪,以便找到 panic 的位置。
最佳答案
简短的回答是:不可能但也有异常(exception)。
Golang 有一些堆栈控制方法和类型。
您可以使用 runtime/debug/SetTraceback 控制堆栈级别
func SetTraceback(level string)
SetTraceback sets the amount of detail printed by the runtime inthe traceback it prints before exiting due to an unrecovered panic or an internal runtime error. The level argument takes the same values as the GOTRACEBACK environment variable. For example, SetTraceback("all") ensure that the program prints all goroutines when it crashes.
See the package runtime documentation for details. If SetTraceback is called with a level lower than that of the environment variable, the call is ignored.
您还可以使用 runtime/debug/Stack 打印堆栈跟踪
func Stack() []byte
Stack returns a formatted stack trace of the goroutine that calls it. It calls runtime.Stack with a large enough buffer to capture the entire trace.
您还需要了解内置函数 recover
的工作原理。
The recover built-in function allows a program to manage behavior of a panicking goroutine. Executing a call to recover inside a deferred function (but not any function called by it) stops the panicking sequence by restoring normal execution and retrieves the error value passed to the call of panic. If recover is called outside the deferred function it will not stop a panicking sequence. In this case, or when the goroutine is not panicking, or if the argument supplied to panic was nil, recover returns nil. Thus the return value from recover reports whether the goroutine is panicking.
func recover() 接口(interface){}
此示例假定包不调用 recover(在另一节中详细介绍)。
package main
import (
"log"
"errors"
"runtime/debug"
"time"
)
func f2() {
panic(errors.New("oops")) // line 11
}
func f1() {
f2() // line 15
}
func main() {
defer func() {
if e := recover(); e != nil {
log.Printf("%s: %s", e, debug.Stack()) // line 20
}
}()
go f1() // line 25
time.Sleep(time.Second * 1)
}
如果代码正在从 panic 中恢复,您需要使用调试器或删除 recover
以了解发生了什么,如下例所示,该示例表明已恢复的 panic 无法“恢复” "再次。
package main
import (
"log"
"errors"
"runtime/debug"
"time"
)
func f2() {
panic(errors.New("oops")) // line 11
}
func f1() {
defer func() {
if e := recover(); e != nil {
log.Printf("internal %s: %s", e, debug.Stack()) // line 20
}
}()
f2() // line 15
}
func main() {
defer func() {
if e := recover(); e != nil {
log.Printf("external %s: %s", e, debug.Stack()) // line 20
} else {
log.Println("Nothing to print")
}
}()
go f1() // line 25
time.Sleep(time.Second * 1)
}
使用 Delve 调试或者临时编辑包以记录完整的消息(一旦理解,您可以恢复更改)。
此外,如果您发现问题,请告知软件包作者,以便进行修复。
关于go - 从导入的包中跟踪 go routine?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39229698/
我使用这些 instructions 在 R 中制作了一个包.我使用 RStudio,我想向包中添加一个新功能。 我是否只是将函数放入 R 脚本并将其拖到名为 R 的包中的文件夹中?如果这样做,是否需
我正在 Rstudio 中构建我的 R 包,当我厌倦了创建包的小插图时遇到了一些意想不到的问题。当我在 Rstudio 中点击构建/加载面板时,出现小插图错误,同时创建了包的文档。为了可能解决我遇到的
我编写了一个 Delphi 包,其中两个组件使用我放置在 GraphContour.res 中的相同 PNG 资源。使用以下脚本创建文件: compile_res.bat: @brcc32 Graph
我有一个包含多个文件的目录,我想将这些文件包含在 Wix 项目构建的 msi 包中。 /database /database/migration11.txt /database/migration21
我想使用基于 git describe 命令的包版本。为此,我使用函数 get_version() 创建了 setup.py。此函数从 .version 文件中检索版本(如果存在),否则计算新的包版本
我创建了一个新的 django 应用程序并将其作为新包上传到 pypi。但是当我们将包安装到项目时,模板文件夹内的 html 文件没有显示。为什么会发生这种情况?下面还给出了 setup.py 文件(
我尝试执行这个 javascript 命令: document.querySelectorAll('div.Dashboard-section div.pure-u-1-1 span.ng-scope
我有(相当多的)静态文件需要与我的应用程序一起部署,该应用程序构建在遗留 .NET 库之上。其中包括几个 XML 和配置文件,以及一个 10 兆字节的只读数据库。 我看到的大多数论坛都指出实现此目的的
假设我有以下文件结构: +mypackage/ foo.m bar.m 如何向 help(mypackage) 的输出添加帮助? 在 python 中,我只是在 __init__.py 中添加
我正在尝试在 C# appx 包中包含数据文件或图像。我已尝试将文件添加到 csproj,并启用“复制到输出目录”,但它们不会出现在 AppXLayouts 目录中。 我在 dev.windows.c
我需要 Python 图像库中的 group4 解码,但为了构建它,我需要将一些更改放入发行版 libtiff-dev 包中。 以前从未做过这种事情,我很好奇从哪里开始。我需要在 libtiff 中进
我正在使用 AOSP,我想创建自己的库并在应用程序中使用它(来自 packages/app/)。我的图书馆只有一门课: import android.app.Fragment; import andr
是否可以在我的 apk 文件中添加一些存储程序版本、更新路径和其他有用数据的 XML 文件(注意:我指的不是 Android XML 文件)。我只想将该文件解压缩到本地数据文件夹的某个位置,我将使用它
问题 我想知道对于计划作为模块导入的 Python 目录的命名是否有标准约定。这意味着该目录包含一个空白的 __init__.py 背景 直到最近,我才很少考虑它,并且完全根据在文件系统级别有意义的内
我正在安装 git.install 的自定义版本包裹。我在 tools 目录中添加了一些额外的文件。 git.install tools file1 file2 choco
有没有办法为包中的示例 map 结构自动生成模板代码? 大多数软件包的根目录下都有一个/example 文件夹,用于展示软件包的功能。我不确定创建示例的“最佳”方式是什么,或者它是否重要。 我是否单独
我正在制作我的第一个 R 包,我正在尝试包含包依赖项。该软件包在我的机器上安装并运行良好,但我已经安装了所有依赖项。当另一个用户尝试安装并且他们没有安装所有依赖项时,他们会收到错误消息。 ERROR:
我正在尝试从以下网址的表格中抓取数据: http://www.nfpa.org/itemDetail.asp?categoryID=953&itemID=23033 问题是包含在 标签。当我使用以
我有一个 R我即将提交给 CRAN 的 GitHub 上的包。到目前为止,该包已经有一个广泛的 README.md 文档,其中显示: 包核心函数执行示例, 包演示执行示例, 一些基准测试结果。 供 G
我已经编写了供私有(private)使用的 Visual Studio 扩展。该软件包仍在开发中,但我想使用它并将其分发给我的同事。是否可以在 .vsix 包中包含调试符号 (.pdb)?与包编辑相比
我是一名优秀的程序员,十分优秀!