提供了一个调试和运行程序的环境。
dbx [ -a ProcessID ] [ -c CommandFile ] [ -d NestingDepth ] [ -I Directory ] [ -E DebugEnvironment ] [ -p oldpath=newpath:...| pathfile ] [ -k ] [ -u ] [ -F ] [ -r ] [ -x ] [ ObjectFile [ CoreFile ] ]
dbx 命令为 C、C++、Pascal 和 FORTRAN 语言程序提供了一个符号性的调试程序,允许您按照下面的内容执行操作:
ObjectFile 参数是一个由编译器产生的对象(可执行)文件。在编译您的程序时,使用 -g(生成符号表)标志产生 dbx 命令需要的信息。
注:cc 命令的 -g 标志应该在对象文件进行编译时使用。如果没有使用 -g 标志或者如果符号引用被 strip 命令从 xcoff 文件中删除了,则 dbx 命令的符号性能将受到限制。
如果没有指定 -c 标志,dbx 命令将会在用户的 $HOME 目录中检查 .dbxinit 文件。然后它在用户当前目录中检查 .dbxinit 文件。如果在当前目录中存在一个 .dbxinit文件,该文件将覆盖用户的 $HOME 目录中的 .dbxinit 文件。如果在发现了 .dbxinit 文件存在于用户的 $HOME 目录中或者当前目录中,该文件的子命令将在调试部分开始时运行。使用编辑器创建一个 .dbxinit 文件。
如果没有指定 ObjectFile,那么 dbx 将询问要进行检查的对象文件的名称。缺省值是 a.out。如果当前目录中存在 core 文件或者指定了 CoreFile 参数,那么 dbx 将报告程序发生错误的位置。保留在核心映像中的变量、寄存器和内存可以被检查直到开始执行 ObjectFile。那时 dbx 调试程序提示输入命令。
dbx 程序可以显示各种各样的表达式。您可以在 dbx 调试程序中使用 C 和 Pascal 语法的公共子集和一些 FORTRAN 扩展的子集来指定表达式。
以下运算符在调试程序中是有效的:
*(星号)或者 ^ (脱字符号) | 表示正在取消引用间接寻址或者指针。 |
[ ](方括号)或者( )(圆括号) | 表示数组表达式的下标。 |
. (句点) | 通过指针和结构来使用该字段引用运算符。这将使得 C 运算符 ->(箭头)变得没有必要,尽管它仍允许使用。 |
&(与符号) | 获得变量的地址。 |
.. (两个句点) | 在指定数组子部分时将上下界分开。例如:n[1..4]。 |
以下类型的运算在调试程序的表达式中是有效的:
代数运算 | =、-、*、/(浮点运算的除法)、div(整数运算的除法)、mod 和 exp(乘幂运算)。 |
按位运算 | -, I, bitand, xor, ~. <<, >> |
逻辑运算 | or、and、not、II 和 && |
比较运算 | <, >, <=, >=, < > or !=, = or == |
其它 | (类型名),sizeof |
逻辑和比较表达式在 stop 和 trace 中作为条件使用的。
检验表达式类型。您可以通过重命名或者重载运算符的方式重设一个表达式类型。三种重命名的格式分别是:类型名(表达式),表达式 |类型名以及 (类型名)表达式。以下是一个示例,其中 x 变量是一个值为 97 的整数:
(dbx) print x 97 (dbx) print char (x), x \ char, (char) x, x 'a' 'a' 'a' 97
dbx 命令提供一种命令行编辑功能类似于由 Korn Shell 提供的功能。vi 模式提供 类似 vi 的编辑功能,而 emacs 模式赋予您类似于 emacs 的控制功能。
这些功能可以通过使用 dbx 子命令 set -o 或者 set edit 来开启。要打开 vi 风格的命令行编辑,您可以输入子命令 set edit vi 或者 set -o vi。
您也可以使用 EDITOR 环境变量来设置编辑模式。
dbx 命令将保存输入到历史文件 .dbxhistory 当中的命令。如果没有设置 DBXHISTFILE 环境变量,使用的历史文件是 $HOME/.dbxhistory。
按照缺省值,dbx 将保存最近输入的 128 个命令。DBXHISTSIZE 环境变量可以从来增加这一限制。
-a ProcessID | 将调试程序和正在运行的进程连接起来。要连接调试程序,您需要拥有对该进程使用 kill 命令的权限。使用 ps 命令来决定进程的 ID。如果您获得许可,dbx 程序中断该进程,决定对象文件的完整名称,读入符号信息和提示输入命令。 |
-c CommandFile | 读入标准输入之前,在文件中运行 dbx 子命令。$HOME 目录中指定的文件将首先被处理;然后处理当前目录中的文件。当前目录中的命令文件将会覆盖 $HOME 目录中的命令文件。如果指定的文件既不存在于 $HOME 目录也不存在于当前目录,将会显示警告消息。source 子命令可以在 dbx 程序运行后使用。 |
-d NestingDepth | 设置程序块的嵌套限制。缺省的嵌套深度限制为 25。 |
-E DebugEnvironment | 指定调试程序的环境变量。 |
-p oldpath=newpath:...| pathfile | 以 oldpath=newpath 的格式在检查核心文件时指定替换的库的路径。oldpath 指定了将被替换的值(存储在核心文件中)而 newpath 指定了将要替换的新的值。这些可能是全部或者部分的,绝对路径或者相对路径。可以指定若干个替换,它们之间用冒号隔开。相反 -p 标志可以指定文件名,映射以前读入的描述格式。每行中只允许有一个映射从文件中读出。 |
-F | 可以用来关闭缓慢读入模式并使 dbx 命令在启动时就读入全部符号。缺省情况下,缓慢读入模式是打开的:它在 dbx 会话初始化时读入需要的符号表信息。。在该模式下,dbx 将不会读入那些符号信息尚未被读入的变量和类型。因此,诸如 whereis i 等命令并不列出在所有函数中的变量 i 的全部实例。 |
-I Directory | (大写 i)将 Directory 变量指定的目录包含到搜索源文件目录列表中。搜索源文件的缺省目录为: |
-k | 映射内存地址;这对于内核调试是非常有用的。 |
-r | 立即运行对象文件。如果它成功结束,dbx 调试程序将会退出。否则,将会进入调试程序并报告中断的原因。
注意:除非指定了 -r,dbx 命令将会提示用户并等待命令输入。 |
-u | 让 dbx 命令为文件名加上 @ (at 符号) 前缀。该标志减少符号名混淆的可能性。 |
-x | 防止 dbx 命令跳过来自于 FORTRAN 源代码的 _(下划线)字符。该符号允许 dbx 在符号之间区别哪些除了下划线以外都是相同的,例如 xxx 和xxx_。 |
$ cc -g samp.c -o samp
samp 程序运行后,操作系统会报告一个总线错误并将核心映像写入到您当前的工作目录当中,如下所示:
$ samp Bus Error - core dumped
要确定发生错误的位置,请输入:
$ dbx samp
系统将会返回如下信息:
dbx version 3.1 Type 'help' for help. reading symbolic information . . . [ using memory image in core] 25 x[i] = 0; (dbx) quit
main() { int i,x[10]; for (i = 0; i < 10;); }
该程序将不会中止因为 i 不会增加。使用 -g 标志编译 looper.c 得到符号调试能力:
$ cc -g looper.c -o looper
在命令行中运行 looper 并执行以下步骤就会在它运行的时候将 dbx 连接到程序中去:
ps -u UserID
其中 UserID 是您的登录标识。所有属于您的活动的进程将会显示如下:
PID TTY TIME COMMAND 68 console 0:04 sh 467 lft3 10:48 looper
在该示例中和 looper 相关的进程 ID 是 467。
$ dbx -a 467
系统将返回如下的信息:
Waiting to attach to process 467 . . . Successfully attached to /tmp/looper. dbx is initializing Type 'help' for help. reading symbolic information . . . attached in main at line 5 5 for (i = 0; i < 10;); (dbx)
现在您可以查询并调试进程如同该程序最初就是由 dbx 来启动的。
$dbx -I /home/user/src -I /home/group/src objfile
use 子命令可以在 dbx 启动之后用来实现此功能。use 命令重新设置目录清单而 -I 标志则向清单中添加目录。
$ dbx -r samp
系统将会返回如下信息:
Entering debug program . . . dbx version 3.1 Type 'help' for help. reading symbolic information . . . bus error in main at line 25 25 x[i] = 0; (dbx) quit
-r 标志允许您在尽管没有设置核心映像的情况下在内存中检查您的进程的状态。
dbx -E LIBPATH=/home/user/lib -E LANG=Ja_JP objfile
注意:这些子命令只能在运行 dbx 调试程序时使用。
/ | 在当前源文件中向前搜索某种模式。 |
? | 在当前源文件中向后搜索某种模式。 |
alias(别名) | 创建 dbx 子命令的别名。 |
assign(赋值) | 为一个变量赋值。 |
attribute(属性) | 显示所有或者选中属性对象的信息。 |
call(调用) | 运行与指定的过程或函数相关的对象代码。 |
case(格式) | 修改 dbx 调试程序解释符号的方式。 |
catch(捕捉) | 在一个信号送到应用程序之前启动捕获这个信号。 |
clear(清除) | 删除所有源指定行的停止线。 |
cleari | 除去地址中所有的断点。 |
condition(条件) | 显示全部或者选中的条件变量的信息。 |
cont | 从当前停止点继续应用程序的执行直到程序终止或者遇到下一个断点。 |
delete(删除) | 删除与指定事件数对应的跟踪和停止线。 |
detach(拆分) | 继续应用程序的执行并退出调试程序。 |
display memory(显示内存) | 显示内存中的内容。 |
down(降下) | 将当前函数在堆栈中向下移动。 |
dump(转存) | 显示指定过程中的变量的名称和值。 |
edit(编辑) | 启动编辑器编辑指定文件。 |
file(文件) | 将当前源文件修改成指定的文件。 |
func(函数) | 将当前函数修改成指定的过程或者函数。 |
goto(跳转到) | 使指定行成为下一个运行的行。 |
gotoi | 修改程序计数器地址。 |
help(帮助) | 显示 dbx 子命令或主题的帮助信息。 |
ignore(忽略) | 在一个信号送到应用程序之前停止捕获这个信号。 |
list(列表) | 显示当前源文件的行。 |
listi | 列出应用程序的指令清单。 |
map(映射) | 显示关于应用程序装入特征的信息。 |
move(移动) | 跳到下一行并显示。 |
multproc(多线程) | 启用或禁用多线程调试。 |
mutex(互斥) | 显示全部或者选中的互斥信息。 |
next(下一个) | 运行应用程序直到下一个源程序行。 |
nexti | 运行应用程序直到下一个机器指令。 |
plugin | 调用插件子命令或显示可用插件名称。 |
pluginload | 装入插件。 |
pluginunload | 卸装插件。 |
print(打印) | 打印表达式的值或运行一个过程并打印过程的返回代码。 |
prompt(提示符) | 修改 dbx 命令提示符。 |
quit(退出) | 停止 dbx 调试程序。 |
registers(寄存器) | 显示所有通用寄存器、系统控制寄存器、浮点寄存器和当前指令寄存器的值。 |
rerun(重新运行) | 按照以前设置的参数开始运行应用程序。 |
return(返回) | 继续应用程序的运行直到达到返回一个指定的过程。 |
rwlock | 显示 rwlocks 的信息。 |
run(运行) | 开始运行一个应用程序。 |
screen(屏幕) | 打开一个 Xwindow 作为 dbx 命令的交互。 |
set(设置) | 为 dbx 调试程序变量定义一个值。 |
sh | 传递命令到 shell 去运行。 |
skip(跳过) | 从当前的停止处继续运行应用程序。 |
source(源) | 从文件中读入 dbx 子命令。 |
status(状态) | 显示活动的跟踪和停止子命令。 |
step(单步) | 运行一个源命令行。 |
stepi | 运行一个机器指令。 |
stophwp | 设置一个硬件的观察点停止。 |
stop(停止) | 停止运行应用程序。 |
stopi | 在指定位置设置停止点。 |
thread(线程) | 显示和控制线程。 |
trace(跟踪) | 打印跟踪信息。 |
tracehwp | 设置硬件观察点跟踪。 |
tracei | 打开跟踪。 |
unalias(取消别名) | 删除别名。 |
unset(取消设置) | 删除一个变量。 |
up(上升) | 将当前函数在堆栈中向上移动。 |
use(使用) | 设置在搜索源文件时要搜索的目录列表。 |
whatis | 显示应用程序组件的声明。 |
where | 显示活动过程和函数的清单。 |
whereis | 显示所有名字匹配指定标识符的符号的全限定。 |
which | 显示给定标识符的全限定。 |
/ [ RegularExpression [ / ] ]
/ 子命令在当前源文件中向前搜索由 RegularExpression 参数指定的模式。不带参数输入 / 子命令将会使 dbx 命令向前搜索以前的正则表达式。搜索将会在文件的结尾折返。
? [ RegularExpression [ ? ] ]
? 子命令在当前源文件中向后搜索由 RegularExpression 参数指定的模式。不带参数输入 ? 子命令将会使 dbx 命令向后搜索以前的正则表达式。搜索将会在文件的结尾折返。
alias [ Name [ [ (Arglist) ] String | Subcommand ] ]
alias 子命令为 dbx 子命令创建别名。Name 参数是要创建的别名。String 参数是 dbx 子命令的序列,在执行完该子命令后可以通过 Name 引用这些序列。如果 alias 子命令没有指定参数,它将显示所有当前的别名。
alias rr rerun
alias printandstep "print n; step"
(dbx) alias px(n) "set $hexints; print n; unset $hexints" (dbx) alias a(x,y) "print symname[x]->symvalue._n_n.name.Id[y]" (dbx) px(126) 0x7e
在本示例中,别名 px 打印了一个十六进制的值而不会永久影响到调试环境。
assign Variable =Expression
assign 子命令分配由 Expression 参数指定的值到 Variable 参数指定的变量当中去。
assign x = 5
assign x = y
assign z = 'z'
assign B = false
assign Y = "Hello World"
set $unsafeassign
参见 Displaying and Modifying Variables。
attribute [ AttributeNumber ... ]
attribute 子命令显示关于 AttributeNumber 参数定义的用户线程、互斥或者条件属性对象的相关信息。如果没有指定参数,将会列出所有的属性对象。
对于列出的每个属性对象,将会显示如下信息:
注意:
attribute
输出类似于:
attr obj_addr type state stack scope prio sched p-shar $a1 0x200035c8 mutex valid no $a2 0x20003628 cond valid no $a3 0x200037c8 thr valid 57344 sys 126 other $a4 0x200050f8 thr valid 57344 pro 126 other
attribute 1 3
输出类似于:
attr obj_addr type state stack scope prio sched p-shar $a1 0x200035c8 mutex valid no $a3 0x200037c8 thr valid 57344 sys 126 other
参见 dbx 命令中 condition 子命令、mutex 子命令、 print 子命令和 thread 子命令。
另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Creating Threads、Using Mutexes 和 Using Condition Variables。
call Procedure ( [ Parameters ] )
call 子命令运行由 Procedure 参数指定的过程。返回代码不会打印出来。如果指定了参数,它们将传给正在运行的过程。
运行 dbx 时要调用一个命令,请输入:
(dbx) call printf("hello") hello
printf 成功返回。
case [ default | mixed | lower | upper ]
case 子命令修改 dbx 调试程序解释符号的方式。缺省的符号处理视当前使用的语言而定。如果当前的语言是 C、C++ 或者没有定义,这些符号将不会合并;如果当前的语言是 FORTRAN 或者 Pascal,这些符号就会合并成小写格式。如果符号需要使用与当前语言不一致的方法解释,则使用该子命令。
不带参数输入 case 子命令将会显示当前的 case 模式。
default | 随当前语言变化。 |
mixed | 按实际显示的情况解释符号。 |
lower | 按小写来解释符号。 |
upper | 按大写来解释符号。 |
参见 Folding Variables to Lowercase and Uppercase。
catch [ SignalNumber | SignalName ]
catch 子命令在信号送到应用程序之前启动捕获这个信号。该子命令在调试应用程序处理例如中断之类的信号时非常有用。待捕获的信号可以分别用 SignalNumber 参数按号码或者用 SignalName 参数按名称来指定。信号名是不区分大小写的,而前缀 SIG 是可选的。如果既没有指定 SignalNumber 也没有指定 SignalName 参数,则将缺省捕获除了 SIGHUP、SIGCLD、SIGALARM 和 SIGKILL 之外的所有信号。如果没有指定参数,将显示当前能够捕获的信号的列表。
clear SourceLine
clear 子命令删除所有给定源文件行的停止。SourceLine 参数可以按照两种格式指定:
要删除第 19 行中设置的断点,请输入:
clear 19
参见 cleari 子命令和 delete 子命令。另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Setting and Deleting Breakpoints。
cleari Address
cleari 子命令清除由 Address 参数指定的地址的所有断点。
请参阅 clear 子命令、delete 子命令和 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Setting and Deleting Breakpoints。
condition [ wait | nowait | ConditionNumber ... ]
condition 子命令显示一个或多个条件变量的相关信息。如果指定了一个或多个 ConditionNumber 参数,condition 子命令将会显示指定条件变量的信息。如果没有指定标志或者参数,condition 子命令列出所有条件变量的清单。
各个条件的信息列表如下:
cv | 按照 $cConditionNumber 的格式指出条件变量的符号名称。 |
obj_addr | 设定条件变量的内存地址。 |
num_wait | 设定条件变量中等待的线程的数量。 |
waiters | 列出等待条件变量的用户线程。 |
注意: dbx 调试程序的print 子命令识别符号条件变量名称并用来显示相应对象的状态。
wait | 显示有等待线程的条件变量。 |
nowait | 显示没有等待线程的条件变量。 |
condition
condition 3
输出类似于:
cv obj_addr num_wait waiters $c3 0x20003290 0
参见 attribute 子命令、mutex 子命令、print 子命令以及thread 子命令。
另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Using Condition Variables。
cont [ SignalNumber | SignalName ]
cont 子命令从当前的断点开始继续执行应用程序直到该程序结束或者遇到另外一个断点。如果通过 SignalNumber 参数(指定信号数)或者 SignalName 参数(指定信号名),该程序将假定已经收到该信号并继续执行。信号名不区分大小写而且前缀 SIG 是可选的。如果没有指定信号,该程序将如同没有停止下来过一样继续执行。
cont
cont SIGQUIT
请参阅 dbx 命令 的 detach 子命 令、dbx 的 goto子命令、dbx 的 next 子命令、dbx 的 skip 子命令、dbx 的 step 子命令。
delete { Number ... | all }
delete 子命令从应用程序中删除跟踪和停止。可以通过 Number 参数来删除指定跟踪和停止,或者通过 all 标志来删除所有跟踪和停止。使用 status 子命令来显示 dbx 调试程序为跟踪和停止生成的相应跟踪号和停止号。
all | 删除所有的跟踪和停止。 |
delete all
delete 4
请参阅 clear 子命令、cleari 子命令、status 子命令和 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Setting and Deleting Breakpoints。
detach [ SignalNumber | SignalName ]
detach 子命令将继续应用程序的执行并退出调试程序。信号可以通过以下任意一项指定:
信号名不区分大小写而且前缀 SIG 是可选的。
如果指定了信号,程序将如同接收到该信号一样继续执行。如果没有指定信号,该程序将如同没有停止下来过一样继续执行。
detach
detach SIGREQUEST
{ Address,Address/ | Address/ [ Count ] } [ Mode ] [ >File ]
不带任何关键字进行初始化的 display memory 子命令将显示由如下因素控制的内存的部分内容:
显示内存的范围是由下面两种方法之一指定的:
在名称之前加上一个 &(与符号)指定符号地址。地址可以是其它地址和 +(加号)、 -(减号)以及 *(间接乘法)运算组成的表达式。任何包含在括号中间的表达式都将认为是一个地址。
>File | 重定向输出到指定的文件。 |
0x3fffe460 / X
&y / 2c
&a_string + 5, &a_string + 7/c
请参阅 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Examining Memory Addresses。
down [ Count ]
down 子命令将当前函数在堆栈中向下移动 Count 级。当前函数用来解析名称。Count 参数的缺省值为 1。
请参阅 up 子命令、where 子命令和 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Displaying a Stack Trace。
dump [ Procedure ] [ >File ]
dump 子命令显示指定过程中的所有变量的名称和数值。如果 Procedure 参数为 . (周期),则所有活动的变量将会被显示。如果没有指定 Procedure 参数,则使用当前的过程。如果使用了 >File 标志,输出将会重定向到指定的文件。
>File | 重定向输出到指定的文件。 |
dump
dump add_count
dump > var.list
请参阅 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Displaying and Modifying Variables。
edit [ Procedure | File ]
edit 子命令为指定文件启动编辑器。文件可以通过 File 参数或者指定 Procedure 参数来指定,其中编辑器将启动并打开包含该过程的文件中。如果没有指定文件,则编辑器将会根据当前的源文件来调用。缺省值为 vi 编辑器。通过把 EDITOR 环境变量重新设置成您想要的编辑器名称来覆盖缺省值。
参见 list 子命令、vi 或者vedit 命令。另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Changing the Current File or Procedure 和 Displaying the Current File。
file [ File ]
file 子命令将当前的源文件换成 File 参数指定的文件;它不会写源文件。File 参数可以指定完整的文件的路径。如果 File 参数没有指定路径,dbx 程序通过搜索使用路径试图找到该文件。如果没有指定 File 参数file 子命令将会显示当前的源文件名。如果路径已知,file 子命令还显示文件的完整或者相对路径名。
参见 func 子命令。另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Changing the Current File or Procedure 和 Displaying the Current File。
func [ Procedure ]
func 子命令将当前函数换到由参数 Procedure 指定的程序或函数。如果没有指定 Procedure 参数缺省值为显示当前的函数。改变当前函数将当前源文件换成包含新函数的文件;当前名称解析的作用域也发生了改变。
参见 file 子命令。另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Changing the Current File or Procedure。
goto SourceLine
goto 子命令使源行成为下一个要运行的行。通常指定的源行必须与当前行在同一函数中。要重设该约束,使用 set 子命令并带有 $unsafegoto 标志。
要使下一个执行的行为第六行,请输入:
goto 6
参见 cont 子命令、gotoi 子命令、 以及set 子命令。
gotoi Address
gotoi 子命令修改程序计数器地址为 Address 参数指定的地址。
要修改程序计数器地址为 0x100002b4,请输入:
gotoi 0x100002b4
参见 goto 子命令。
help [ Subcommand | Topic ]
根据您指定的参数 help 子命令显示 dbx 子命令或主题的帮助信息。输入 help 子命令并带有 Subcommand 参数显示语法语句和指定子命令的描述。输入 help 子命令并带有 Topic 参数显示指定主题的详细描述。以下是可用的主题:
帮助
help list
help set_variables
ignore [ SignalNumber | SignalName ]
ignore 子命令在信号送到应用程序之前停止指定信号的捕捉。该子命令在调试应用程序处理例如中断之类的信号时非常有用。
要捕捉的信号可以通过以下任意一项指定:
信号名是不区分大小写的。前缀 SIG 是可选的。
如果既没有指定SignalNumber 也没有指定 SignalName 参数,按缺省将捕捉除了 SIGHUP、SIGCLD、SIGALRM 以及 SIGKILL 以外的所有信号。如果 SIGTRAP 信号来自调试器以外的进程,dbx 调试程序无法忽略该信号。如果没有指定参数,将会显示当前所有被忽略的信号的列表。
要使 dbx 忽略发送到应用程序的警报时钟超时信号,请输入:
ignore alrm
参见 catch 子命令。另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Handling Signals。
list [ Procedure | SourceLine-Expression [ ,SourceLine-Expression ] ]
list 子命令显示指定数目的源文件的行。行数由以下两种方法中的一种来指定:
在这种情况下,list 子命令显示从指定过程开始前的几行开始直到列表窗口已满。
SourceLine-Expression 参数由一个有效的行号,加上可选的 +(加号)或 -(减号),以及一个整数组成。另外,SourceLine $(美元符号)可以用来表示当前行号;SourceLine @ (at 符号) 可以用来表示要列出的下一行的行号。
所有在第一个指定的行号和第二个指定的行号之间(包括这两行)的行都将被显示出来。
如果没指定第二个源行,则只打印第一行。
如果 list 子命令没有指定参数,则将从当前源文件的行开始,打印 $listwindow 所指定的行数。
要修改列表行数的默认值,可以设置特定的调试程序变量,$listwindow,为您想要的行数。$listwindow 的初始值为 10。
list 1,10
list main
list $-5,$+5
(dbx) list $ 4 { (dbx) list 5 5 char i = '4'; (dbx) list sub 23 char *sub(s,a,k) 24 int a; 25 enum status k; . . . (dbx) move 25 (dbx) list @ -2 23 char *sub(s,a,k)
参见 edit 子命令、listi 子命令以及move 子命令。另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Displaying the Current File。
listi [ Procedure | at SourceLine | Address [ , Address ] ]
listi 子命令显示源文件指定的指令集合。显示的指令可以通过下列方法指定:
如果 listi 子命令没有使用标志或参数,则显示下一个 $listwindow 指令。要修改当前列表窗口的大小,可以使用 set $listwindow=Value 子命令。
dbx 程序可以反汇编 POWER 系列 系列或者 POWER PC 体系结构指令。在默认模式下,dbx 程序显示正在运行的结构的指令。
dbx 命令中的 set 子命令的 $instructionset 以及 $mnemonics 变量在允许您覆盖默认的反汇编方式。要获得更多的信息,请参见dbx 命令中的 set 子命令。
SourceLine | 指定了列表的开始命令行。 |
listi
listi at 10
listi at "sample.c":5
listi 0x10000400, 0x10000420
参见 list 子命令以及 set 子命令。另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Debuggingat the Machine Level with dbx。
map [ > File ]
map 子命令显示应用程序中每个装入部分的特征。该信息包括导入的每个装入的模块的名称、文本来源、文本长度、数据来源以及数据长度。
> File | 重定向输出到指定的文件。 |
请参阅 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Debugging at the Machine Level with dbx。
move SourceLine
move 子命令将下一个显示行更换为由 SourceLine 参数指定的行。该子命令修改 @ (at 符号) 变量的值。
SourceLine 变量可以通过一个整数或者代表文件名的字符串后跟 :(冒号)和一个整数的方法指定。
参见 list 子命令。另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Displaying the Current File。
multproc [ on | parent | child | off ]
multproc 子命令指定 dbx 调试程序在创建派生或者越权进程时的行为。on 标志用来指定一个新的 dbx 会话将会被创建以调试派生进程的子路径。原先的dbx 将会继续调试原来的父路径。parent 以及 child 标志用来指定派生进程的单独路径。除了off 的所有标志都能使 dbx 跟随越权进程。off 标志禁用多进程调试。如果没有指定标志,multproc 子命令返回当前调试的多进程的状态。
dbx 程序使用 Xwindows 来进行多进程调试。dbx 程序将会打开足够多的窗口供多进程调试使用。每个子窗口的标题为子进程 ID(pid)。要在进程之间切换,使用 Xwindows 处理技术来激活 dbx 会话显示的窗口。如果系统不支持 Xwindows,在调试派生进程时将会出现一个警告信息而 dbx 程序继续仅调试父进程。多进程调试也可能因如下原因失败:
如果$xdisplay 设置成远程显示,用户可能看不见新创建的 Xwindow。如果$xdisplay 设置不正确,Xwindows 或者其他的系统资源将会报告发生错误的原因。
dbx 程序不能区分不同类型错误的区别,但是将会在子命令失败时发送如下的信息:
Warning: dbx subcommand multiproc fails. dbx continued with multproc disabled.
新创建窗口的用户定义的配置可以在 .Xdefaults 文件中由 dbx_term 应用程序名定义。
on | 启用多进程调试。 |
off | 禁用多进程调试。 |
参见screen 子命令以及 fork 子例程。另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Debugging Programs Involving Multiple Processes。
mutex [ lock | unlock | thnum | utid | MutexNumber ... ]
mutex 子命令显示关于互斥的信息。如果给定 MutexNumber参数mutex 子命令将显示指定互斥的信息。如果没有指定标志或者参数,mutex 子命令将会显示所有的互斥信息。
每个互斥信息列出如下:
注意: dbx 调试程序的 print 子命令识别互斥符号名,然后能用来显示相应对象的状态。
lock | 显示关于锁定互斥的信息。 |
unlock | 显示关于未锁定互斥的信息。 |
thnum | 显示特定线程的所有互斥的信息。 |
utid | 显示用户线程 id 与给定用户线程 id 符合的用户线程的所有互斥信息。 |
mutex
mutex 4 5 6
输出类似于:
mutex obj_addr type lock owner blockers $m4 0x20003274 non-rec no $m5 0x20003280 recursi no $m6 0x2000328a fast no
mutex thnum 1
mutex utid 0x0001
参见attribute 子命令、condition 子命令、print 子命令以及 thread 子命令。
另见AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Using Mutexes。
next [ Number ]
next 子命令运行应用程序到下一行。Number 参数指定 next 子命令运行的次数。如果没有指定 Number 参数,next 只运行一次。
如果您在多线程应用程序中使用 next 子命令,操作期间运行所有的用户线程,但是该程序继续运行直到运行到指定的行。如果您想单步运行正在运行的线程,使用 set 子命令对 $hold_next变量进行设置。设置该变量将可能导致死锁,因为运行中的线程可能等待某个阻塞的线程拥有的锁。
请参阅 cont 子命令、goto 子命令、nexti 子命令、set 子命令以及 step 子命令。
nexti [ Number ]
nexti 子命令运行应用程序到下一个指令。Number 参数指定nexti 子命令运行的次数。如果没有指定 Number 参数,nexti 只运行一次。
如果您在多线程应用程序中使用 nexti 子命令,所有的用户线程在操作期间都将运行,但是程序将会继续运行直到运行的线程达到指定的机器指令。如果您想单步运行正在运行的线程,使用 set 子命令对 $hold_next变量进行设置。设置该变量将可能导致死锁,因为运行中的线程可能等待某个阻塞的线程拥有的锁。
参见gotoi 子命令、next 子命令、set 子命令以及stepi 子命令。另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Running a Program at the Machine Level。
plugin [ Name [ Command ] ]
plugin 子命令将 Command 参数指定的命令传递到 Name 参数指定的插件。如果未指定参数,将显示所有可用插件的名称。
plugin
plugin sample help
plugin xyz interpret 0x20000688
请参阅 pluginload 子命令和 pluginunload 子命令。另见 AIX 5L Version 5.2 General Programming Concepts 中的“Developing for the dbx Plug-in Framework”。
pluginload File
The pluginload 子命令装入 File 参数指定的插件。File 参数应指定该插件的路径。
要装入位于“/home/user/dbx_plugins/libdbx_sample.so”的,名称为“sample”的插件,请输入:
pluginload /home/user/dbx_plugins/libdbx_sample.so
请参阅 plugin 子命令和 pluginunload 子命令。另见 AIX 5L Version 5.2 General Programming Concepts 中的“Developing for the dbx Plug-in Framework”。
pluginunload Name
pluginunload 子命令卸装 Name 参数指定的插件。
要卸装名称为“sample”的插件,请输入:
pluginunload sample
请参阅 plugin 子命令和 pluginload 子命令。 另见 AIX 5L Version 5.2 General Programming Concepts 中的“Developing for the dbx Plug-in Framework”。
print 表达式 ...
print Procedure ( [ Parameters ] )
print 子命令打印执行以下任务:
参见assign 子命令、call 子命令以及 set 子命令。
prompt [ "String" ]
prompt 子命令将 dbx 命令的提示符修改为String 参数指定的字符串。
要将提示符更改为 dbx>,请输入:
prompt "dbx>"
请参阅 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Defining a New dbx Prompt。
quit
quit 子命令结束所有在 dbx 调试对话中的进程。
参见 detach 子命令。
registers [ >File ]
registers 子命令显示通用寄存器、系统控制寄存器、浮点数寄存器以及当前指令寄存器的值。
注意: 寄存器的值可以设置成十六进制数 0xdeadbeef。十六进制数 0xdeadbeef 是一个在进程初始化时就赋到通用寄存器中的初始值。
注意:如果当前线程正处于内核模式,registers 子命令将不能显示寄存器。
>File | 重定向输出到指定的文件。 |
参见set 子命令和 unset 子命令。另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Using Machine Registers。
rerun [ Arguments ] [ < File ] [ > File ] [ > > File ] [ 2> File ] [ 2> > File ] [ >& File ] [ > >& File ]
rerun 子命令开始对象文件的执行。Arguments 参数将会作为一个命令行参数使用。如果没有指定 Arguments 参数,最近一次 run 或者 rerun 子命令使用的参数将会被再次使用。
<File | 将输入重定向使得从 File文件中获得输入。 |
>File | 重定向输出到 File文件中。 |
> >File | 添加重定向输出到 File 中。 |
2>File | 将标准错误重定向到 File 中。 |
2> >File | 添加重定向标准错误到 File 中。 |
>&File | 将输出和标准错误重定向到 File 中。 |
> >&File | 添加输出和标准错误到 File 中。 |
参见 run 子命令。
return [ Procedure ]
return 子命令使应用程序执行直到返回到由 Procedure 参数指定的过程。如果没有指定 Procedure 参数,执行将会在当前过程返回时停止。
rwlock [read | write | RwlockNumber....]
rwlock 子命令显示 rwlocks 的信息。如果给定 RwlockNumber 参数,rwlock 子命令将会显示指定 rwlocks 的信息。如果没有指定标志或者参数,rwlock 子命令将会显示所有 rwlocks 的信息。
每个 rwlock 的信息如下:
注意: dbx 调试程序的print 子命令识别 rwlock 的符号名称并能用于显示其对应的对象的状态。
read | 显示所有处于读状态的 rwlock 的信息。 |
write | 显示所有处于写状态的 rwlock 的信息。 |
rwlock
输出类似于:
rwl flag_value owner status $rwl 1 $t1 write rsleeps[ 0]: wsleeps[ 0]:
rwlock write
输出类似于:
rwl flag_value owner status $rwl 1 $t1 write rsleeps[ 0]: wsleeps[ 0]:
参见attribute 子命令、condition 子命令、 mutex 子命令、print 子命令以及 thread 子命令。
run [ Arguments ] [ <File ] [ >File ] [ > >File ] [ 2>File ] [ 2> >File ] [ >&File ] [ > >&File ]
run 子命令打开对象文件。Arguments 参数将会作为一个命令行参数使用。
<File | 将输入重定向使得从 File文件中获得输入。 |
>File | 重定向输出到 File文件中。 |
2>File | 将标准错误重定向到 File 中。 |
> >File | 添加重定向输出到 File 中。 |
2> >File | 添加重定向标准错误到 File 中。 |
>&File | 将输出和标准错误重定向到 File 中。 |
> >&File | 添加输出和标准错误到 File 中。 |
要带参数 blue 和 12 运行应用程序,请输入:
run blue 12
参见 rerun 子命令。
screen
screen 子命令为 dbx 命令交互打开一个 Xwindow 窗口。您可以在进程发生的窗口继续操作。
screen 子命令必须在 dbx 调试程序运行在一个 Xwindows 环境下时运行。如果 screen 子命令运行于非 Xwindow 环境下,dbx 程序将会显示一个警告信息并且继续执行调试过程如同没有设定 screen 子命令。screen 子命令也可能在下述情况下失败:
dbx 程序不能区分不同类型错误的区别,但是将会在子命令失败时发送如下的信息:
Warning:dbx subcommand screen fails. dbx continues.
如果$xdisplay 设置成远程显示,用户可能看不见新创建的 Xwindow。如果$xdisplay 设置不正确,Xwindows 或者其他的系统资源将会报告发生该问题。
新创建窗口的用户定义的配置可以在 .Xdefaults 文件中由 dbx_term 应用程序名定义。
要打开一个 dbx 命令交互的 Xwindow 窗口,请输入:
screen
请参阅 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Separating dbx Output From Program Output 和 AIX 5L Version 5.2 AIXwindows Programming Guide 中的 AIXwindows Overview。
set [ Variable=Expression ]
set 子命令为 dbx 调试程序变量定义一个值。其值由 Expression 参数指定;而程序变量由 Variable 参数指定。变量名不得和正在调试的程序中的使用名称相冲突。在其它命令内部扩展变量至相应的表达式。如果 set 子命令没有参数使用,将会显示当前的变量。
以下变量可以用 set 子命令设置:
$catchbp | 在下一个命令执行期间捕捉断点。 |
$expandunions | 显示变体记录或变体联合的每个部分的值。 |
$frame | 使用由 $frame 的值指定的地址所指向的堆栈框架,来执行堆栈跟踪和访问局部变量。 |
$hexchars | 按照十六进制值打印字符。 |
$hexin | 按照十六进制解释地址。 |
$hexints | 按照十六进制数值打印整数。 |
$hexstrings | 按照十六进制打印字符指针。 |
$hold_next | 控制在运行 cont、next、nexti 和 step 子命令时获得除了正在运行线程之外的所有线程。设置该变量将可能导致死锁,因为运行中的线程可能等待某个阻塞的线程拥有的锁。 |
$ignoreifhandler | 您的程序接收到带已注册处理程序的信号时,请勿停止。 |
$ignoreload | 在您运行 load、 unload或者 loadbind 子例程时不会停止。 |
$ignorenonbptrap | 您的程序遇到非断点捕获指令且具有已注册的 SIGTRAP 处理程序,请勿停止。 |
$instructionset | 重设默认反汇编方式。以下列表包含了 Expression 参数可能取的值:
如果没有设置 Expression 参数,dbx 将会使用缺省反汇编方式。 |
+$java | 如果设置了上面的参数,还将设置以下变量,并将 dbx 放入某种方式来调试 Java 应用程序。如果取消设置,还将取消设置以下变量:
|
$listwindow | 指定一个函数列表的行数以及不加参数使用 list 子命令时的列表的行数。缺省值是 10 行。 |
$mapaddrs | 开始映射地址。取消 $mapaddrs 设置将停止地址映射。 |
$mnemonics | 修改反汇编时 dbx 程序的助记符设置。
如果没有设置 Expression 参数值dbx 程序将会最接近指定指令集的助记符。 |
$noargs | 省略来自子命令的参数,例如 where、up、down 和 dump。 |
$noflregs | 省略 registers 子命令中浮点寄存器的显示。 |
$octin | 解释八进制的地址。 |
$octints | 打印八进制的整数。 |
$pretty | 与 print 子命令连用,按照 pretty printed 格式显示复杂的 C 及 C++ 数据结构(结构、联合、数组)的值。
|
$repeat | 如果没有输入命令则重复前一个命令。 |
$sigblock | 程序的阻塞信号。 |
$stepignore | 控制在 step 子命令运行某一源行时 dbx 如何动作,该源行调用另一个无调试信息可返回的例程。该变量使得 step 子命令可以跳过大的无法获得调试信息的例程。以下列表包含了 Expression 参数可能取的值: |
$unsafe 变量限制了 dbx 调试程序在错误检测中的用途。
set $listwindow=20
set $unsafeassign
set $instructionset="601"
参见 unset 子命令。另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Changing Print Output with Special Debug Program Variables。
set 子命令带有 -o 或者 edit 选项可以用来打开某一行编辑模式。如果给出了 set-o vi 或者 set edit vi 命令,您将处于 vi 行编辑器的输入模式。如果给了 set -o emacs 或者 set edit emacs 命令,您将处于 emacs 行编辑器的输入模式。
set-o vi
或
set edit vi
sh [ Command ]
sh 子命令将 Command 参数指定的命令传递到 shell 执行。SHELL 环境变量决定使用哪个 shell。缺省值为 sh shell。如果没有指定参数,将把控制权交给 shell。
请参阅 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Running Shell Commands from dbx。
skip [ Number ]
skip 子命令从当前的停止点继续执行程序。数目等于 Number 参数的值的断点将会被跳过并将在下一个断点处或者程序结束时停止执行。如果没有指定 Number 参数,缺省值为 1。
要继续执行程序直到遇到第二个断点,请输入:
skip 1
也可参见 cont 子命令。
source File
source 子命令从File参数指定的文件读入 dbx 子命令。
要从 cmdfile 文件中读 dbx 子命令,请输入:
source cmdfile
请参阅 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Reading dbx Subcommands from a File。
status [ >File ]
status 子命令显示当前活动的 trace 和 stop 子命令。> 标志将 status 子命令的输出发送给 File 参数指定的文件。
>File | 重定向输出到 File文件中。 |
参见 dbx 命令的 clear 子命令、delete 子命令、stop 子命令、trace 子命令。
另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Setting and Deleting Breakpoints。
step [ Number ]
step 子命令运行应用程序源命令行。通过 Number 参数指定执行的行数。如果省略了 Number 参数,缺省值为 1。
如果在多线程应用程序中使用 step 子命令,操作期间所有的用户线程都将运行,但是程序继续执行直到运行线程达到指定的源程序行。如果您想单步运行正在运行的线程,使用 set 子命令对 $hold_next变量进行设置。设置该变量将可能导致死锁,因为运行中的线程可能等待某个阻塞的线程拥有的锁。
注意: 使用set 子命令的 $stepignore 变量来控制 step 子命令的行为。 $stepignore 变量使 step 子命令单步跳过大的无法获得调试信息的例程。
step
step 5
60 printf ("hello world \n");
请输入:
set $stepignore="function"; step
参见 cont 子命令、goto 子命令、next 子命令、set 子命令以及 stepi 子命令。
stepi [ Number ]
stepi 子命令运行应用程序的指令。通过 Number 参数指定执行的指令数。如果省略了 Number 参数,缺省值为 1。
如果在多线程应用程序上使用,stepi 子命令只单步执行当前运行线程。所有其它的线程都将停止。
参见 gotoi 子命令、 nexti 子命令、 step 子命令。
stop { [Variable] [ at SourceLine | in Procedure ] [ if Condition ]}
stop 子命令在满足特定条件时停止应用程序。应用程序将会在下列条件停止:
SourceLine 变量可以通过一个整数或者代表文件名的字符串后跟 :(冒号)和一个整数的方法指定。
完成任意命令后,dbx 调试程序产生一个消息报告它已作为命令结果产生。该消息包括和您的断点相关的事件的 ID 以及您的命令的解释。解释的语法并不一定和您的命令相同。示例:
stop in main
[1] stop in main
stop at 19 if x == 3
[2] stop at "hello.c":19 if x = 3
方括号中的数字是和断点相关的事件的标识符。dbx 调试程序将事件数和每个 stop 子命令联系起来。当一个事件导致程序停止后,事件标识符将与当前行一同显示,以说明导致程序停止的事件。您所创建的事件和由 dbx命令生成的内部事件共存,因此事件号可能不总是顺序的。
使用 status 子命令来查看这些数字。您可以重定向 status 的输出到一个文件当中。使用 delete 或者 clear 子命令来关闭 stop 子命令。
在多线程应用程序中,所有用户线程都将在任何用户线程遇到断点时停止。在源文件行和函数中设置的断点将会被任何执行该行和该函数的用户线程遇到,除非您按照下述例 9 的方式指定条件。以下别名自动指定条件:
ThreadNumber 是线程符号名的数字部分,由 thread 子命令报告(例如,5 是名为 $t5 的线程的 ThreadNumber)。这些别名实际上是宏,它们产生扩展子命令如下:
stopi at &Function if ($running_thread == ThreadNumber) stop at SourceLine if ($running_thread == ThreadNumber)
at SourceLine | 指定行号。 |
if Condition | 指定条件,例如真值。 |
in Procedure | 指定调用的过程。 |
stop in main
stop x at 12
stop at "sample.c":5
stop in func1 if x = 22
stopi at &func1 if x = 22
stop Variable
stop if (x > y) and (x < 2000)
status [1] stop in main [2] stop at "hello.c":19 if x = 3 delete 1 status [2] stop at "hello.c":19 if x = 3 clear 19 status (dbx)
delete 命令用事件标识符删除事件。clear 命令通过行号删除了断点。
stopi at &func1 if ($running_thread == 5)
或
bfth(func1, 5)
参见clear 子命令、delete 子命令、stopi 子命令以及 trace 子命令。另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Setting and Deleting Breakpoints。
stophwp Address Size
stophwp 子命令为指定的内存区域设置一个硬件监视点停止。如果区域的内容改变程序就将停止。
stophwp 0x200004e8 4
参见 tracehwp 子命令。
stopi { [Address] [ at Address | in Procedure ] [ if Condition ]}
stopi 子命令在指定的位置设置一个停止点:
if Condition | 指定条件,例如真值。 |
in Procedure | 指定调用的过程。 |
at Address | 指定机器指令地址。 |
stopi at 0x100020f0
stopi 0x100020f0
stopi 0x200020f0 if ($running_thread == 1)
参见 stop 子命令。另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Debugging at the Machine Level with dbx。
thread { [ info ] [ - ] [ ThreadNumber ... ] } | current | run | susp | term | wait
thread current [ - ] ThreadNumber
thread { hold | unhold } [ - ] [ ThreadNumber ... ]
thread { help}
thread 子命令显示和控制用户线程。
thread 子命令的第一种形式可以两种格式显示信息。如果 thread 子命令是 th那么将会使用第一种格式显示信息。如果 thread 子命令是 th -,那么将会按照第二种格式显示信息。如果没有指定参数,则会显示所有用户线程的信息。如果指定了一个或者更多的 ThreadNumber 参数,则会显示相关用户线程的信息。thread 子命令显示线程时,当前线程行将以 > 开头。如果运行中的线程和当前的线程不一致,该行前将会加上 * 符号。由 thread 子命令按照两种方式显示的信息如下。
由 thread 子命令按照第一种方式显示的信息如下:
由 thread 子命令按照第二种方式显示的信息如下。按照缺省值,对于 thread 子命令 th - 参数,显示的信息是长格式。
thread | 按照 $tThreadNumber格式指出用户线程的符号名。 |
核心线程的相关信息
tid | 指出用户线程标识符(如果用户线程连接了核心线程)。 |
pri | 指出了核心线程的优先级。 |
sched | 指出了核心线程的调度策略。它可以是 fif、oth 或者 rr,分别对应 fifo、其它和环(round robin)调度策略。 |
state | 指出核心线程的状态(如果用户线程连接了核心线程)。它可以是 run、wait、susp 或者 zomb,分别对应运行、等待、挂起和僵尸(zombie)状态。 |
用户线程相关信息
tid | 指出用户线程标识符。 |
pri | 指出用户线程的优先级。 |
sched | 指出了用户线程的调度策略。它可以是 fif、oth 或者 rr,分别对应 fifo、其它和环(round robin)调度策略。 |
state | 指出用户线程的状态。可以是 running、 creating、 suspended、 blocked、 runnable 或者 terminated。 |
state | 按照十六进制指出用户状态。 |
flags | 按照十六进制指出 pthread 标志的值。 |
wchan | 指出核心线程正在等待或者睡眠的事件(如果用户线程连接了核心线程)。 |
mode | 指出用户线程停止的方式(如果用户线程连接到了核心线程),它可以是核心方式或用户方式。 |
held | 指出是否保持用户线程。 |
scope | 指出用户线程的争用作用域;对于系统或者进程争用域分别是 sys 或者 pro。 |
cancellation |
|
joinable | 指出线程是否可以连接。 |
boosted | 指出线程 boosted 值。 |
function | 指出用户线程函数的名称。 |
cursig | 指出当前信号的值。 |
如果设置了可选项 $thcomp,则将会按照如下的压缩格式显示信息。
m mode (k)ernel (u)ser k k-state (r)unning (w)aiting (s)uspended (z)ombie u u-state (r)unning (R)unnable (s)uspended (t)erminated (b)locked (c)reating h held (yes) (n)o s scope (s)ystem (p)rocess c cancellation not pending: (e)nabled & (d)eferred, (e)nabled & (a)sync, (d)isabled pending : (E)nabled & (D)eferred, (E)nabled & (A)sync, (D)isabled j joinable (yes) (n)o b boosted value of boosted field in pthread structure plk kernel thread (oth)er (fif)o (rr)-> round-robin policy plu user thread (oth)er (fif)o (rr)-> round-robin policy prk kernel thread hex number policy pru user thread hex number policy k-tid 十六进制的内核线程标识 u-tid 十六进制的 pthread 标识 fl 十六进制的 pthread 结构中的标志字段的值 sta 十六进制的 pthread 结构中的状态字段的值 cs 当前信号值 wchan 线程正在等待的事件 function 函数名
thread 子命令的第二种格式用来选择当前线程。dbx 调试程序的 print、registers 以及 where 子命令都在当前线程的上下文中工作。如果当前的线程处于核心模式 registers 子命令不能显示寄存器。
thread 子命令的第三种格式用来控制线程的执行。可以使用 hold 标志保持线程,或者使用 unhold 标志释放线程。保持的线程将不会再继续直到它被释放。
注意: dbx 调试程序的 print 子命令识别线程的符号名并可以显示相应对象的状态。
thread state-k wchan state-u k-tid mode held scope function $t1 wait running 17381 u no pro main $t3 wait running 8169 u no pro iothread
thread 1 3 4
输出类似于:
thread state-k wchan state-u k-tid mode held scope function $t1 wait running 17381 u no pro main $t3 wait running 8169 u no pro iothread >$t4 run running 9669 u no pro save_thr
thread wait -
输出类似于:
thread m k u h s c j b kpl upl kpr upr k_tid u_tid fl sta wchan function *$t1 u r w n p ed y 0 oth oth 61 1 0043e5 000001 51 004 main $t3 u r w n p ed y 0 oth oth 61 1 001fe9 000102 51 004 iothread >$t4 u r r n p ed y 0 oth oth 61 1 0025c5 000203 50 064 save_thr
thread - 1 2 3
输出类似于:
thread m k u h s c j b kpl upl kpr upr k_tid u_tid fl sta wchan function *$t1 u r w n p ed y 0 oth oth 61 1 0043e5 000001 51 004 main $t3 u r w n p ed y 0 oth oth 61 1 00fe9 000102 51 004 iothread >$t4 u r r n p ed y 0 oth oth 61 1 0025c5 000203 50 064 save_thr
参见 attribute 子命令、condition 子命令、mutex 子命令、print 子命令、registers 子命令以及 where 子命令。
另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Creating Threads。
trace [ SourceLine | Expression at SourceLine | Procedure | [ Variable ] [ at SourceLine | in Procedure ] ] [ if Condition ]
程序运行时 trace 子命令打印指定过程、函数、命令行、表达式或者变量的跟踪信息。SourceLine 变量可以通过一个整数或者代表文件名的字符串后跟 :(冒号)和一个整数的方法指定。可以指定条件。dbx 调试程序将一个数字和每个 trace 子命令联系起来。使用 status 子命令来查看这些数字。使用 delete 子命令来关闭跟踪。
根据缺省值,跟踪是基于进程的。要创建基于线程的跟踪,按照 例 8 的条件指定线程。
at SourceLine | 指定发现被跟踪的表达式的源行。 |
if Condition | 指定跟踪开始的条件。跟踪只有在 if Condition 为真时开始执行。 |
in Procedure | 指定用来发现被跟踪的过程或者变量的过程。 |
trace printf
trace "hello.c":22
trace x in main
set $A=0x2004000 trace $A
注意:tracei 子命令是用来跟踪地址的。
(dbx) trace in sub2 [1] trace in sub2 (dbx) run trace in hellosub.c: 8 printf("%s",s); trace in hellosub.c: 9 i = '5'; trace in hellosub.c: 10 }
(dbx) trace sub [1] trace sub (dbx) run calling sub(s = "hello", a = -1, k = delete) from function main returning "hello" from sub
(dbx) trace x*17 at "hellosub.c":8 if (x > 0) [1] trace x*17 at "hellosub.c":8 if x > 0 (dbx) run at line 8 in file "hellosub.c": x*17 = 51 (dbx) trace x [1] trace x initially (at line 4 in "hello.c"): x = 0 after line 17 in "hello.c": x = 3
(dbx) trace x if ($running_thread == 1)
也可参见 tracei 子命令。
tracehwp Address Size
tracehwp 子命令为指定的内存区域设置一个硬件监视点停止。如果区域的内容发生了变化,dbx 调试程序打印跟踪信息。
tracehwp 0x200004e8 4
参见 stophwp 子命令。
tracei [ [ Address ] [ at Address | in Procedure ] | Expression at Address ] [ if Condition ]
tracei 子命令在如下情况下开启跟踪:
at Address | 指定一个地址。当该地址处的指令被运行时可以启用跟踪。 |
if Condition | 指定条件。当满足该条件时启用跟踪。 |
in Procedure | 指定一个过程。该过程处于活动时启用跟踪。 |
tracei
tracei at 0x100020f0
tracei 0x20004020 in main
tracei at 0x100020f0 if ($running_thread == 4)
参见 trace 子命令。另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Debugging at the Machine Level with dbx。
unalias Name
unalias 子命令删除由 Name 参数指定的别名。
要删除名称为 printx 的别名,请输入:
unalias printx
参见 alias 子命令。另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Creating Subcommand Aliases。
unset Name
unset 子命令删除和由参数 Name 指定的名称相关的 dbx 调试程序变量。
要删除禁止显示浮点数寄存器的变量,请输入:
unset $noflregs
参见 set 子命令。另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Changing Print Output With Special Debugging Variables。
up [ Count ]
up 子命令将当前函数在堆栈内向上移动 Count 级。当前函数用来解析名称。Count 参数的缺省值为 1。
参见 down 子命令。另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Changing the Current File or Procedure、Displaying a Stack Trace。
use [ Directory ... ]
use 子命令设置当 dbx 调试命令寻找源文件时要搜索的目录列表。如果没有指定 use 子命令的参数,将会显示要搜索的当前目录列表。
@ (at 符号) 是一个特殊符号,它指示 dbx 程序查找对象文件中的完整路径名信息,如果存在的话。如果您有一个叫 @ 的相关目录要搜索,您可以在搜索路径中使用 ./@ 。
use 子命令使用 +(加号)来向搜索目录列表中添加目录。如果您有一个名为 + 的目录,指定一个完整的目录路径名(例如,./+ 或者 /tmp/+)。
use . .. /tmp
use . @ ../source
use + /tmp2
whatis Name
whatis 子命令显示 Name 的声明,其中 Name 参数指定了变量、过程或者函数的名称,块名称可选。
注意: 只有在 dbx 调试程序运行时使用 whatis 子命令。
whatis x
whatis main
whatis main.x
(dbx) whatis $$status enum $$status { run, create, delete, suspend };
where [ >File ]
where 子命令显示活动过程和函数的列表。通过使用 >File标志可将此子命令的输出重定向到指定文件。
>File | 重定向输出到指定的文件。 |
参见 up 子命令和 down 子命令。另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Displaying a Stack Trace。
whereis Identifier
whereis 子命令显示所有名称符合指定标识符的符号的完整修饰符。符号打印的顺序并不重要。
要显示名称为 x 的所有符号的修饰符,请输入:
whereis x
也可参见 which 子命令。
which Identifier
which 子命令显示给定标识符的完整的修饰符。完整的修饰符包括和该标识符相关的外部块的列表。
要显示 x 符号的完整修饰符,请输入:
which x
请参阅 whereis 子命令。另见 AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Scoping of Names。
a.out | 对象文件;包含对象代码。 |
core | 包含核心转储。 |
.dbxinit | 包含初始命令。 |
adb 命令和 cc 命令。
AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 dbx Symbolic Debug Program Overview 和 Using the dbx Debug Program。