gh (Go with Exception Handled)
gh命令将给定线程的异常标识为已处理,并且允许该线程从产生异常的指令继续执行。
语法
用户模式语法
[~Thread] gh[a] [= StartAddress] [BreakAddress ... [; BreakCommands]]
内核模式语法
gh[a] [= StartAddress] [BreakAddress ... [; BreakCommands]]
参数
- Thread
- (仅用户模式) 指定要执行的线程。该线程必须是因为异常而停止的。详细信息查看线程语法。
- a
- 使得任何用该命令创建的断点成为处理器断点(就像用ba创建的一样)
,而不是软断点(像用bp
和 bm创建的一样)。如果没有指定BreakAddress,则不会创建断点并且a标志无效。
- StartAddress
- 指定要开始执行的地址。如果没有指定,调试器将执行传递给指令计数器的当前值所指向的地址。语法的详细信息,查看地址和地址范围语法。
- BreakAddress
- 指定断点的地址。如果设置了BreakAddres,它必须是一个指令地址(即该地址必须是某条指令第一个字节的地址)。一次可以以任意顺序设置最多10个断点地址。如果BreakAddress
还未能确定,它将被作为未定断点保存起来。语法的详细信息,查看地址和地址范围语法。
- BreakCommands
- 指定当遇到BreakAddress 设置的断点时要自动执行的命令。BreakCommands
参数必须以一个分号开头。如果指定了多个BreakAddress值,BreakCommands 会应用到每一个上。
注意 BreakCommands 参数仅在将它包含在另一个命令的命令字符串中时可用 —
例如,在另一条断点命令或一个异常或事件设置中。在一个命令行中,分号会结束gh命令,并且分号之后的所有附加命令会在gh完成之后立即执行。
环境
模式 |
用户模式、内核模式 |
目标 |
仅活动调试 |
平台 |
所有 |
注释
如果使用BreakAddress 参数来设置断点,该断点只会在当前线程触发。其他线程执行到指定的代码位置时不会停止下来。
如果指定了Thread ,gh 命令将指定线程解冻并冻结其他所有线程然后再执行。例如,如果使用~123gh、~#gh或~*gh命令,指定线程会是解冻的,而其他所有线程都被冻结。
附加信息
关于其他执行该命令的方法和相关命令的概述,查看控制调试目标。
Build machine: CAPEBUILD