意外的 VS Code 调试器值

Unexpected VS Code debugger values

提问人:Megidd 提问时间:6/1/2023 最后编辑:Zeke LuMegidd 更新时间:6/8/2023 访问量:45

问:

功能

我有这个功能来检测四面体的体积是否几乎为零,即它是平坦的:


import (
    "math"

    v3 "github.com/deadsy/sdfx/vec/v3"
)

// MATHEMATICA script is available here:
// https://math.stackexchange.com/a/4709610/197913
func isZeroVolume(a, b, c, d v3.Vec) (bool, float64) {
    ab := b.Sub(a)
    ac := c.Sub(a)
    ad := d.Sub(a)

    // Note that the `Norm` function of MATHEMATICA is equivalent to our `Length()` function.
    nab := ab.Length()
    ncd := ac.Sub(ad).Length()
    nbd := ab.Sub(ad).Length()
    nbc := ab.Sub(ac).Length()
    nac := ac.Length()
    nad := ad.Length()

    // Check for 0 edge lengths
    if nab == 0 || ncd == 0 ||
        nbd == 0 || nbc == 0 ||
        nac == 0 || nad == 0 {
        return true, 0
    }

    volume := 1.0 / 6.0 * math.Abs(ab.Cross(ac).Dot(ad))
    denom := (nab + ncd) * (nac + nbd) * (nad + nbc)

    // Tolerance derived from here:
    // https://math.stackexchange.com/a/4709610/197913
    tolerance := 480.0

    rho := tolerance * volume / denom

    return rho < 1, volume
}

输入

我使用以下四个输入点逐步完成代码:

{X: -1.572793602943422, Y: -4.157202807477221, Z: 5.603983008116483}
{X: -2.45160644054413, Y: -3.4214927673339854, Z: 6.135950530673543}
{X: -2.45160644054413, Y: -3.7163730403986044, Z: 5.603983008116483}
{X: -1.572793602943422, Y: -3.5355907043553003, Z: 6.482795845717191}

调试器

通过 VS Code 调试器单步执行代码指示局部变量具有以下值:

Screenshot

问题

调试器显示的值没有意义。怎么可能和是?这对我来说毫无意义。我错过了什么吗?denomtolerance0

Go visual-studio-code 调试 vscode-debugger delve

评论


答:

0赞 Megidd 6/1/2023 #1

好吧,我只是继续通过调试器单步执行代码,这些值现在符合预期。就像 :tolerance

Screenshot

我不知道如何以及为什么通过继续步进来纠正它......

1赞 Zeke Lu 6/8/2023 #2

以下是演示的简化版本,以显示该问题:

 1  package main
 2  
 3  func main() {
 4      a := f(1)
 5      b := 1
 6  
 7      c := a < b
 8      _ = c
 9  }
10  
11  func f(i int) int {
12      if i > 0 {
13          return i
14      }
15      return -i
16  }

下面是 delve 调试会话的输出:

(dlv) b 7
Breakpoint 2 set at 0x4608de for main.main() ./main.go:7
(dlv) c
> main.main() ./main.go:7 (hits goroutine(1):1 total:1) (PC: 0x4608de)
     2: 
     3: func main() {
     4:     a := f(1)
     5:     b := 1
     6: 
=>   7:     c := a < b
     8:     _ = c
     9: }
    10: 
    11: func f(i int) int {
    12:     if i > 0 {
(dlv) locals
a = 824633745824
b = 824633843808
(dlv) disass
TEXT main.main(SB) /home/zeke/src/temp/76380802/main.go
    main.go:3   0x4608c0    493b6610            cmp rsp, qword ptr [r14+0x10]
    main.go:3   0x4608c4    7639                jbe 0x4608ff
    main.go:3   0x4608c6    4883ec28            sub rsp, 0x28
    main.go:3   0x4608ca    48896c2420          mov qword ptr [rsp+0x20], rbp
    main.go:3   0x4608cf    488d6c2420          lea rbp, ptr [rsp+0x20]
    main.go:4   0x4608d4    b801000000          mov eax, 0x1
    main.go:4   0x4608d9    e842000000          call $main.f
=>  main.go:7   0x4608de*   4883f801            cmp rax, 0x1
    main.go:4   0x4608e2    4889442418          mov qword ptr [rsp+0x18], rax
    main.go:5   0x4608e7    48c744241001000000  mov qword ptr [rsp+0x10], 0x1
    main.go:7   0x4608f0    0f9c44240f          setl byte ptr [rsp+0xf]
    main.go:9   0x4608f5    488b6c2420          mov rbp, qword ptr [rsp+0x20]
    main.go:9   0x4608fa    4883c428            add rsp, 0x28
    main.go:9   0x4608fe    c3                  ret
    main.go:3   0x4608ff    90                  nop
    main.go:3   0x460900    e83bccffff          call $runtime.morestack_noctxt
    main.go:3   0x460905    ebb9                jmp $main.main

您会看到该指令被选为行 处的断点 。此时,变量 和 还没有得到它们的值( 稍后在指令中获取值,而 在 )。0x4608de:7aba0x4608e2b0x4608e7

这就是为什么你一开始没有得到正确的值,它后来会“自我修复”。

此问题已被报告为变量 #58813 的 cmd/compile: bad DWARF location