Как gdb печатает адрес var в go программе? - PullRequest
0 голосов
/ 04 июня 2018

Я успешно установил GDB 8.0.1 и запустил его в Mac OS X.При отладке этой программы я не вижу адрес key.

package main

func main(){
    m := map[string]int{
        "abc":123,
    }

    key := []byte("abc")
    x, ok := m[string(key)]
    println(x, ok)
}

Вот что я сделал с gdb:

go build -gcflags "-N" test_append.go
gdb test_append
(gdb) b 9
Breakpoint 1 at 0x104d4b4: file /Users/jiamo/go/src/test/test_append.go, line 9.
(gdb) c
The program is not being run.
(gdb) run
Starting program: /Users/jiamo/go/src/test/test_append
Thread 3 hit Breakpoint 1, main.main () at /Users/jiamo/go/src/test/test_append.go:9
9       x, ok := m[string(key)]
(gdb) info locals
key =  []uint8 = {97 'a', 98 'b', 99 'c'}
m = map[string]int = {["abc"] = 123}
ok = false
x = 17195648
(gdb) p key
$1 =  []uint8 * = {97 'a', 98 'b', 99 'c'}
(gdb) p &key
$2 =  []uint8 * = {97 'a', 98 'b', 99 'c'}

Я смотрю на lldb.(lldb нужно b на main.main, затем b на линии)

(lldb) b main.main
Breakpoint 1: where = test_append`main.main + 50 at test_append.go:4, address = 0x000000000104d372
(lldb) run
(lldb) b 9
(lldb) c
(lldb) fr v
    ([]uint8) key = (len 3, cap 32) {
    [0] = 97
    [1] = 98
    [2] = 99
    }
    # no address too

(lldb) p key
([]uint8) key = (len 3, cap 32) {
[0] = 97
[1] = 98
[2] = 99
}
(lldb) p &key
(*[]uint8)  = 0x000000c420055e10 (len 0, cap 0)   
# now it can show the address, 
# And I am not sure why it becomes (len 0, cap 0) 

И мой вопрос: как можно показать адрес key в gdb?

1 Ответ

0 голосов
/ 30 июня 2018

Вы можете отключить симпатичные принтеры Python для Go, тогда вы получите следующее:

(gdb) print key
$1 = {array = 0xc42003de10 "abc", len = 3, cap = 32}

Или вы можете временно переключиться на язык C, например:

(gdb) set language c
Warning: the current language does not match this frame.
(gdb) print key
$1 =  []uint8 = {97 'a', 98 'b', 99 'c'}
(gdb) print (char *)key
$2 = 0xc420043e10 "abc"
(gdb) 

Это предполагает, что массивы Go интерпретируются GDB определенным образом в режиме C, но, похоже, в этом случае это работает.

...