我在 IBM AIX 下使用 dbx 进行调试。我看到以下内容:
(dbx) print $r4
0x00000001614aa050
(dbx) print *((int64*)0x00000001614aa050)
-1
(dbx) print $r3
0x0000000165e08468
Then I "stepi" my 64bit program which executed the following instruction:
std r3,0x0(r4)
然后我立即检查了该内存的内容:
(dbx) print *((int64*)0x00000001614aa050)
-1
还是-1?我期待 $r3 中的内容应该保存到该内存中。然后我使用我的变量手动将值分配给该地址:
(dbx) print &bmc._pLong
0x00000001614aa050
(dbx) assign bmc._pLong=(int64 *)0x0000000165e08468
(dbx) print *((int64*)0x00000001614aa050)
6004180072 (which is 0x0000000165e08468)
怎么会这样?