<?xml version="1.0" encoding="utf-8"?><?xml-stylesheet type='text/xsl' href='http://netroc682.spaces.live.com/mmm2008-07-24_12.50/rsspretty.aspx?rssquery=en-US;http%3a%2f%2fnetroc682.spaces.live.com%2ffeed.rss' version='1.0'?><rss version="2.0" xmlns:slash="http://purl.org/rss/1.0/modules/slash/" xmlns:msn="http://schemas.microsoft.com/msn/spaces/2005/rss" xmlns:live="http://schemas.microsoft.com/live/spaces/2006/rss" xmlns:dcterms="http://purl.org/dc/terms/" xmlns:cf="http://www.microsoft.com/schemas/rss/core/2005" xmlns:wfw="http://wellformedweb.org/CommentAPI/"><channel><title>netroc的共享空间</title><description /><link>http://netroc682.spaces.live.com/</link><language>en-US</language><pubDate>Mon, 18 Aug 2008 03:24:19 GMT</pubDate><lastBuildDate>Mon, 18 Aug 2008 03:24:19 GMT</lastBuildDate><generator>Microsoft Spaces v1.1</generator><docs>http://www.rssboard.org/rss-specification</docs><ttl>60</ttl><live:identity><live:id>-5341356082337814461</live:id><live:alias>netroc682</live:alias></live:identity><image><title>netroc的共享空间</title><url>http://byfiles.storage.live.com/y1p0qpXoeNk96mu28dmDAQiIHCNyTh4eKRFFTadArTXxbjo9rIttLhxcA</url><link>http://netroc682.spaces.live.com/</link></image><cf:listinfo><cf:group ns="http://schemas.microsoft.com/live/spaces/2006/rss" element="typelabel" label="Type" /><cf:group ns="http://schemas.microsoft.com/live/spaces/2006/rss" element="tag" label="Tag" /><cf:group element="category" label="Category" /><cf:sort element="pubDate" label="Date" data-type="date" default="true" /><cf:sort element="title" label="Title" data-type="string" /><cf:sort ns="http://purl.org/rss/1.0/modules/slash/" element="comments" label="Comments" data-type="number" /></cf:listinfo><item><title>WinDbg 文档翻译----91</title><link>http://netroc682.spaces.live.com/Blog/cns!B5DFB0F15D61E843!312.entry</link><description>&lt;p&gt;&lt;span style="font-family:宋体;font-size:10pt"&gt;cc682/NetRoc
&lt;/span&gt;&lt;p&gt;&lt;a href="http://netroc682.spaces.live.com/"&gt;&lt;span style="font-family:宋体;font-size:10pt"&gt;http://netroc682.spaces.live.com/&lt;/span&gt;&lt;/a&gt;
	&lt;h1&gt;!evlog
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!evlog&lt;/strong&gt; 扩展命令用于显示、修改或者备份事件日志(event log)。 
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!evlog addsource&lt;/strong&gt; [&lt;strong&gt;-d&lt;/strong&gt;] [&lt;strong&gt;-s &lt;/strong&gt;&lt;em&gt;Source&lt;/em&gt;] [&lt;strong&gt;-t&lt;/strong&gt; &lt;em&gt;Type&lt;/em&gt;] [&lt;strong&gt;-f&lt;/strong&gt; &lt;em&gt;MsgFile&lt;/em&gt;] &lt;br&gt;&lt;strong&gt;!evlog backup&lt;/strong&gt; [&lt;strong&gt;-d&lt;/strong&gt;] [&lt;strong&gt;-l&lt;/strong&gt; &lt;em&gt;EventLog&lt;/em&gt;] [&lt;strong&gt;-f&lt;/strong&gt; &lt;em&gt;BackupFile&lt;/em&gt;] &lt;br&gt;&lt;strong&gt;!evlog clear&lt;/strong&gt; [&lt;strong&gt;-!&lt;/strong&gt;] [&lt;strong&gt;-d&lt;/strong&gt;] [&lt;strong&gt;-l&lt;/strong&gt; &lt;em&gt;EventLog&lt;/em&gt;] [&lt;strong&gt;-f&lt;/strong&gt; &lt;em&gt;BackupFile&lt;/em&gt;] &lt;br&gt;&lt;strong&gt;!evlog info&lt;/strong&gt; &lt;br&gt;&lt;strong&gt;!evlog option&lt;/strong&gt; [&lt;strong&gt;-d&lt;/strong&gt;] [&lt;strong&gt;-!&lt;/strong&gt;] [&lt;strong&gt;-n&lt;/strong&gt; &lt;em&gt;Count&lt;/em&gt;] [ &lt;strong&gt;-l&lt;/strong&gt; &lt;em&gt;EventLog&lt;/em&gt; [ &lt;strong&gt;-+&lt;/strong&gt; | &lt;strong&gt;-r&lt;/strong&gt; &lt;em&gt;RecordBound&lt;/em&gt; ]] [&lt;strong&gt;-o&lt;/strong&gt; &lt;em&gt;Order&lt;/em&gt;] [&lt;strong&gt;-w&lt;/strong&gt; &lt;em&gt;Width&lt;/em&gt;] &lt;br&gt;&lt;strong&gt;!evlog read&lt;/strong&gt; [&lt;strong&gt;-d&lt;/strong&gt;] [&lt;strong&gt;-l&lt;/strong&gt; &lt;em&gt;EventLog&lt;/em&gt;] [&lt;strong&gt;-s &lt;/strong&gt;&lt;em&gt;Source&lt;/em&gt;] [&lt;strong&gt;-e&lt;/strong&gt; &lt;em&gt;ID&lt;/em&gt;] [&lt;strong&gt;-c&lt;/strong&gt; &lt;em&gt;Category&lt;/em&gt;] [&lt;strong&gt;-t&lt;/strong&gt; &lt;em&gt;Type&lt;/em&gt;] [&lt;strong&gt;-n&lt;/strong&gt; &lt;em&gt;Count&lt;/em&gt;] [&lt;strong&gt;-r&lt;/strong&gt; &lt;em&gt;Record&lt;/em&gt;] &lt;br&gt;&lt;strong&gt;!evlog report&lt;/strong&gt; [&lt;strong&gt;-s &lt;/strong&gt;&lt;em&gt;Source&lt;/em&gt;] [&lt;strong&gt;-e&lt;/strong&gt; &lt;em&gt;ID&lt;/em&gt;] [&lt;strong&gt;-c&lt;/strong&gt; &lt;em&gt;Category&lt;/em&gt;] [&lt;strong&gt;-t&lt;/strong&gt; &lt;em&gt;Type&lt;/em&gt;] &lt;em&gt;Message&lt;/em&gt; &lt;br&gt;&lt;strong&gt;!evlog&lt;/strong&gt; [&lt;em&gt;Option&lt;/em&gt;] &lt;strong&gt;-?&lt;/strong&gt; &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;strong&gt;addsource&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;将一个事件源(event source)加入到注册表中。默认情况下，只会添加来自&lt;strong&gt;DebuggerExtensions&lt;/strong&gt; 的事件(用于支持&lt;strong&gt;!evlog report&lt;/strong&gt;)。
&lt;p&gt;&lt;strong&gt;backup&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;对指定的事件日志创建一个备份，并且写入到文件中。 
&lt;p&gt;&lt;strong&gt;clear&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;清除指定的事件日志，并且选择性的创建一个文件用于保存它的旧内容。 
&lt;p&gt;&lt;strong&gt;info&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;显示事件日志的摘要信息。 
&lt;p&gt;&lt;strong&gt;option&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;设置默认的搜索选项。这些选项用于之后的&lt;strong&gt;!evlog read&lt;/strong&gt; 命令。 
&lt;p&gt;&lt;strong&gt;read&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;显示记录到指定的事件日志中的事件清单。输出的详细程度 — 例如要显示的记录条数和排序方式 — 可以通过&lt;strong&gt;!evlog read&lt;/strong&gt; 的参数或者之前使用&lt;strong&gt;!evlog option&lt;/strong&gt; 来控制。 
&lt;p&gt;&lt;strong&gt;report&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;将某个事件记录写入应用程序事件日志(application event log)中。
&lt;p&gt;&lt;strong&gt;-d&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;指定要使用的所有默认值。&lt;strong&gt;-d&lt;/strong&gt; 选项仅在省略了其他&lt;em&gt;所有&lt;/em&gt;参数时需要使用。但是，和&lt;strong&gt;!evlog option&lt;/strong&gt; 一起使用时可以用来显示已存在的默认设置。 
&lt;p&gt;&lt;strong&gt;-!&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;和&lt;strong&gt;!evlog option&lt;/strong&gt;一起使用来重置为默认选项。和&lt;strong&gt;!evlog clear&lt;/strong&gt;一起使用 阻止创建备份文件。 
&lt;p&gt;&lt;em&gt;Source&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定事件源。默认值为&lt;strong&gt;DebuggerExtensions&lt;/strong&gt;。
&lt;p&gt;&lt;em&gt;Type&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定成功类型(success type)。可能的&lt;em&gt;Type&lt;/em&gt;值有 1 (Error)、 2 (Warning)、 4 (Information)、 8 (Audit_Success)、或者16 (Audit_Failure)。值为0表示成功。对于 &lt;strong&gt;!evlog read&lt;/strong&gt; 和&lt;strong&gt;!evlog report&lt;/strong&gt;，默认是成功Success (0)。对于&lt;strong&gt;!evlog addsource&lt;/strong&gt;，可以结合使用这些位，并且默认设置了所有位(31)。
&lt;p&gt;&lt;em&gt;MsgFile&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定消息文件的路径和文件名。如果省略路径，则使用当前&lt;em&gt;Uext.dll&lt;/em&gt;所在目录。 
&lt;p&gt;&lt;em&gt;EventLog&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;对于&lt;strong&gt;!evlog read&lt;/strong&gt;、&lt;strong&gt;!evlog backup&lt;/strong&gt;、和&lt;strong&gt;!evlog clear&lt;/strong&gt;，&lt;em&gt;EventLog&lt;/em&gt; 指定要读取哪个事件日志。可能的值有&lt;strong&gt;Application&lt;/strong&gt;、&lt;strong&gt;System&lt;/strong&gt;、和&lt;strong&gt;Security&lt;/strong&gt;。默认为&lt;strong&gt;Application&lt;/strong&gt;。
&lt;p style="margin-left:21pt"&gt;对于&lt;strong&gt;!evlog option&lt;/strong&gt;， &lt;em&gt;EventLog&lt;/em&gt; 指定要设置最大数量(maximum count)的事件日志。可能的值有&lt;strong&gt;All&lt;/strong&gt;、&lt;strong&gt;Application&lt;/strong&gt;、&lt;strong&gt;System&lt;/strong&gt;和 &lt;strong&gt;Security&lt;/strong&gt;。默认为&lt;strong&gt;All&lt;/strong&gt;。
&lt;p&gt;&lt;em&gt;BackupFile&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定备份文件的路径和文件名。默认位置是当前目录。默认文件名是&lt;strong&gt;&lt;em&gt;EventLog&lt;/em&gt;&lt;/strong&gt;_&lt;em&gt;backup.evt&lt;/em&gt;，&lt;em&gt;EventLog&lt;/em&gt; 是在该命令中使用的事件日志。如果文件已经存在，命令会终止执行。 
&lt;p&gt;&lt;em&gt;Count&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定要获取的记录的最大数量。默认为20。
&lt;p&gt;&lt;strong&gt;-+&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;指定用后面的&lt;strong&gt;!evlog read&lt;/strong&gt;命令获取的最大记录数量作为当前最大记录数量。(换句话说，只要前面没有进行过搜索就不会显示出记录来。) 
&lt;p&gt;&lt;em&gt;RecordBound&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定之后的&lt;strong&gt;!evlog read&lt;/strong&gt; 命令能获取的最大记录数量。如果指定0，则不会有限制 — 这是默认。 
&lt;p&gt;&lt;em&gt;Record&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;如果没有包含&lt;strong&gt;-n&lt;/strong&gt;
		&lt;em&gt;Count&lt;/em&gt;，&lt;strong&gt;-r&lt;/strong&gt;
		&lt;em&gt;Record&lt;/em&gt; 用于指定要获取的记录条数。如果包含了&lt;strong&gt;-n&lt;/strong&gt;
		&lt;em&gt;Count&lt;/em&gt;，&lt;em&gt;Record&lt;/em&gt;用于指定显示从第几条记录开始。 
&lt;p&gt;&lt;em&gt;Order&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定搜索顺序，可以是&lt;strong&gt;Forwards&lt;/strong&gt; 或&lt;strong&gt;Backwards&lt;/strong&gt;。默认为&lt;strong&gt;Forwards&lt;/strong&gt;。反向搜索会从最近一次记录到事件日志中的记录开始，并且反方向进行搜索直到找到匹配项。
&lt;p&gt;&lt;em&gt;Width&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定数据显示的宽度，以字符为单位。这是在Data部分的显示宽度。默认为8个字符。 
&lt;p&gt;&lt;em&gt;ID&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定事件之前要显示的前缀。可以使用的值有 0 (no prefix)、 1000 (Information)、2000 (Success)、 3000 (Warning)、和 4000 (Error)。默认为0。
&lt;p&gt;&lt;em&gt;Category&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定事件种类。可使用的值有0 (no category)、 1 (Devices)、 2 (Disk)、 3 (Printers)、 4 (Services)、 5 (Shell)、6 (System_Event)和 7 (Network)。默认为0。 
&lt;p&gt;&lt;em&gt;Message&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定要添加到事件描述中的文本消息。 
&lt;p&gt;&lt;em&gt;Option&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定要显示某个&lt;strong&gt;!evlog&lt;/strong&gt; 选项的帮助文本。 
&lt;p&gt;&lt;strong&gt;-?&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;在调试器命令窗口中显示该扩展命令的简短帮助。 
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:151px"&gt;&lt;col style="width:104px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Uext.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Uext.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Uext.dll&lt;/em&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;p&gt;
 &lt;p&gt;&lt;strong&gt;!evlog&lt;/strong&gt; 扩展只能在活动调试时使用。
&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;使用&lt;strong&gt;!evlog addsource&lt;/strong&gt; 在注册表中添加了事件源之后，可以使用&lt;a&gt;&lt;strong&gt;!dreg&lt;/strong&gt;&lt;/a&gt;命令来查看它的值。例如：
&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;0:000&amp;gt; &lt;strong&gt;!dreg hklm\system\currentcontrolset\services\eventlog\Application\&amp;lt;source&amp;gt;!*&lt;/strong&gt; &lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;&lt;strong&gt;!evlog option&lt;/strong&gt; 命令用于为&lt;strong&gt;!evlog read&lt;/strong&gt; 设置新的默认值。这可以避免在重复使用&lt;strong&gt;!evlog read&lt;/strong&gt; 时每次都需要输入所有参数。使用&lt;strong&gt;-+&lt;/strong&gt;参数或者&lt;strong&gt;-r&lt;/strong&gt;
		&lt;em&gt;Records&lt;/em&gt; 参数可以为搜索进行限制，在搜索了指定数量的记录之后终止命令。如果仅对某个事件之后的记录感兴趣，那么这种限制是很有用的。&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;使用&lt;strong&gt;!evlog report&lt;/strong&gt;前，应该用&lt;strong&gt;!evlog addsource&lt;/strong&gt; 来在注册表中配置事件源。这种配置之后，事件查看器就可以识别各种事件ID了。 
&lt;p style="margin-left:21pt"&gt;下面是&lt;strong&gt;!evlog info&lt;/strong&gt; 扩展命令的示例：
&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;0:000&amp;gt; &lt;strong&gt;!evlog info -?&lt;/strong&gt;&lt;br&gt;--------------------------------&lt;br&gt;Application Event Log:&lt;br&gt;  # Records       : 4362&lt;br&gt;  Oldest Record # : 1&lt;br&gt;  Newest Record # : 4362&lt;br&gt;  Event Log Full  : false&lt;br&gt;--------------------------------&lt;br&gt;System Event Log:&lt;br&gt;  # Records       : 2296&lt;br&gt;  Oldest Record # : 1&lt;br&gt;  Newest Record # : 2296&lt;br&gt;  Event Log Full  : false&lt;br&gt;--------------------------------&lt;br&gt;Security Event Log:&lt;br&gt;  # Records       : 54544&lt;br&gt;  Oldest Record # : 1&lt;br&gt;  Newest Record # : 54544&lt;br&gt;  Event Log Full  : false&lt;br&gt;--------------------------------&lt;br&gt;&lt;br&gt;0:000&amp;gt; &lt;strong&gt;!evlog option -n 4&lt;/strong&gt;&lt;br&gt;Default EvLog Option Settings:&lt;br&gt;--------------------------------&lt;br&gt;Max Records Returned: 4&lt;br&gt;Search Order:         Backwards&lt;br&gt;Data Display Width:   8&lt;br&gt;--------------------------------&lt;br&gt;Bounding Record Numbers:&lt;br&gt;  Application Event Log: 0&lt;br&gt;  System Event Log:      0&lt;br&gt;  Security Event Log:    0&lt;br&gt;--------------------------------&lt;br&gt;&lt;br&gt;0:000&amp;gt; &lt;strong&gt;!evlog read -l application&lt;/strong&gt;&lt;br&gt;-------------- 01 --------------&lt;br&gt;Record #: 4364&lt;br&gt;&lt;br&gt;Event Type:      Error (1)&lt;br&gt;Event Source:    Userenv&lt;br&gt;Event Category:  None (0)&lt;br&gt;Event ID:        1000 (0xC00003E8)&lt;br&gt;Date:            06/06/2002&lt;br&gt;Time:            18:03:17&lt;br&gt;Description:     (1 strings)&lt;br&gt;The Group Policy client-side extension Security was passed flags (17) and returned a failure status code of (87).&lt;br&gt;&lt;br&gt;-------------- 02 --------------&lt;br&gt;Record #: 4363&lt;br&gt;&lt;br&gt;Event Type:      Warning (2)&lt;br&gt;Event Source:    SceCli&lt;br&gt;Event Category:  None (0)&lt;br&gt;Event ID:        1202 (0x800004B2)&lt;br&gt;Date:            06/06/2002&lt;br&gt;Time:            18:03:17&lt;br&gt;Description:     (1 strings)&lt;br&gt;0x57 : The parameter is incorrect.&lt;br&gt;Please look for more details in TroubleShooting section in Security Help.&lt;br&gt;&lt;br&gt;-------------- 03 --------------&lt;br&gt;Record #: 4362&lt;br&gt;&lt;br&gt;Event Type:      Error (1)&lt;br&gt;Event Source:    Userenv&lt;br&gt;Event Category:  None (0)&lt;br&gt;Event ID:        1000 (0xC00003E8)&lt;br&gt;Date:            06/06/2002&lt;br&gt;Time:            16:04:08&lt;br&gt;Description:     (1 strings)&lt;br&gt;The Group Policy client-side extension Security was passed flags (17) and returned a failure status code of (87).&lt;br&gt;&lt;br&gt;-------------- 04 --------------&lt;br&gt;Record #: 4361&lt;br&gt;&lt;br&gt;Event Type:      Warning (2)&lt;br&gt;Event Source:    SceCli&lt;br&gt;Event Category:  None (0)&lt;br&gt;Event ID:        1202 (0x800004B2)&lt;br&gt;Date:            06/06/2002&lt;br&gt;Time:            16:04:08&lt;br&gt;Description:     (1 strings)&lt;br&gt;0x57 : The parameter is incorrect.&lt;br&gt;Please look for more details in TroubleShooting section in Security Help.&lt;br&gt;WARNING: Max record count (4) exceeded, increase record count to view more
&lt;/span&gt;&lt;h1&gt;!findstack
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!findstack &lt;/strong&gt;扩展命令用于在所有调用堆栈中定位包含指定符号或模块的位置。 
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!findstack&lt;/strong&gt; &lt;em&gt;Symbol &lt;/em&gt;[&lt;em&gt;DisplayLevel&lt;/em&gt;]&lt;br&gt;&lt;strong&gt;!findstack&lt;/strong&gt; -&lt;strong&gt;?&lt;/strong&gt; &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;em&gt;Symbol&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定符号或者模块。 
&lt;p&gt;&lt;em&gt;DisplayLevel&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定显示中要包含的内容。可以是下面这些值中的一个，默认值是1。 
&lt;p style="margin-left:21pt"&gt;0 
&lt;p style="margin-left:21pt"&gt;仅显示每个包含&lt;em&gt;Symbol&lt;/em&gt;的线程的ID。 
&lt;p style="margin-left:21pt"&gt;1 
&lt;p style="margin-left:21pt"&gt;显示包含&lt;em&gt;Symbol&lt;/em&gt;的每个线程的ID和frame。 
&lt;p style="margin-left:21pt"&gt;2 
&lt;p style="margin-left:21pt"&gt;显示每个包含&lt;em&gt;Symbol&lt;/em&gt;的线程的整个调用堆栈。 
&lt;p&gt;&lt;strong&gt;-?&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;在调试器命令窗口中显示该扩展命令的简单帮助。 
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:151px"&gt;&lt;col style="width:104px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Uext.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Uext.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Uext.dll&lt;/em&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;内核模式下的&lt;a&gt;&lt;strong&gt;!stacks&lt;/strong&gt;&lt;/a&gt;命令可以显示所有线程的调用堆栈和状态摘要信息。 
&lt;p style="margin-left:21pt"&gt;下面是该扩展命令输出的示例：
&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;0:023&amp;gt; &lt;strong&gt;!uext.findstack wininet&lt;/strong&gt;&lt;br&gt;Thread 009, 2 frame(s) match&lt;br&gt;        * 06 03eaffac 771d9263 wininet!ICAsyncThread::SelectThread+0x22a&lt;br&gt;        * 07 03eaffb4 7c80b50b wininet!ICAsyncThread::SelectThreadWrapper+0xd&lt;br&gt; &lt;br&gt;Thread 011, 2 frame(s) match&lt;br&gt;        * 04 03f6ffb0 771cda1d wininet!AUTO_PROXY_DLLS::DoThreadProcessing+0xa1&lt;br&gt;        * 05 03f6ffb4 7c80b50b wininet!AutoProxyThreadFunc+0xb&lt;br&gt; &lt;br&gt;Thread 020, 6 frame(s) match&lt;br&gt;        * 18 090dfde8 771db73a wininet!CheckForNoNetOverride+0x9c&lt;br&gt;        * 19 090dfe18 771c5e4d wininet!InternetAutodialIfNotLocalHost+0x220&lt;br&gt;        * 20 090dfe8c 771c5d6a wininet!ParseUrlForHttp_Fsm+0x135&lt;br&gt;        * 21 090dfe98 771bcb2c wininet!CFsm_ParseUrlForHttp::RunSM+0x2b&lt;br&gt;        * 22 090dfeb0 771d734a wininet!CFsm::Run+0x39&lt;br&gt;        * 23 090dfee0 77f6ad84 wininet!CFsm::RunWorkItem+0x79&lt;br&gt; &lt;br&gt;Thread 023, 9 frame(s) match&lt;br&gt;        * 16 0bd4fe00 771bd256 wininet!ICSocket::Connect_Start+0x17e&lt;br&gt;        * 17 0bd4fe0c 771bcb2c wininet!CFsm_SocketConnect::RunSM+0x42&lt;br&gt;        * 18 0bd4fe24 771bcada wininet!CFsm::Run+0x39&lt;br&gt;        * 19 0bd4fe3c 771bd22b wininet!DoFsm+0x25&lt;br&gt;        * 20 0bd4fe4c 771bd706 wininet!ICSocket::Connect+0x32&lt;br&gt;        * 21 0bd4fe8c 771bd4cb wininet!HTTP_REQUEST_HANDLE_OBJECT::OpenConnection_Fsm+0x391&lt;br&gt;        * 22 0bd4fe98 771bcb2c wininet!CFsm_OpenConnection::RunSM+0x33&lt;br&gt;        * 23 0bd4feb0 771d734a wininet!CFsm::Run+0x39&lt;br&gt;        * 24 0bd4fee0 77f6ad84 wininet!CFsm::RunWorkItem+0x79&lt;br&gt; &lt;br&gt;0:023&amp;gt; &lt;strong&gt;!uext.findstack wininet!CFsm::Run 0&lt;/strong&gt;&lt;br&gt;Thread 020, 2 frame(s) match&lt;br&gt;Thread 023, 3 frame(s) match&lt;br&gt;&lt;br&gt;0:023&amp;gt; &lt;strong&gt;!uext.findstack wininet!CFsm 0&lt;/strong&gt;&lt;br&gt;Thread 020, 3 frame(s) match&lt;br&gt;Thread 023, 5 frame(s) match&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;附加信息&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;关于堆栈回溯和显示调用堆栈的其他方式的信息，查看&lt;a&gt;查看调用堆栈&lt;/a&gt;和&lt;a&gt;&lt;strong&gt;k, kb, kd, kp, kP, kv &lt;/strong&gt;(Display Stack Backtrace)&lt;/a&gt; 命令。
&lt;h1&gt;!gatom
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!gatom&lt;/strong&gt; 扩展用于显示全局atom表(global atom table)。
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!gatom&lt;/strong&gt; &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:151px"&gt;&lt;col style="width:104px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;附加信息
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;关于全局atom表的信息，查看Microsoft Windows SDK文档。
&lt;h1&gt;!igrep
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!igrep&lt;/strong&gt; 扩展命令在反汇编中搜索指定的模板。 
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!igrep&lt;/strong&gt; [&lt;em&gt;Pattern&lt;/em&gt; [&lt;em&gt;StartAddress&lt;/em&gt;]] &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;em&gt;Pattern&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定要搜索的模板。如果省略，则使用前一次的&lt;em&gt;Pattern&lt;/em&gt;。 
&lt;p&gt;&lt;em&gt;StartAddress&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定开始搜索的16进制地址。如果省略，则使用当前程序计数器。 
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:151px"&gt;&lt;col style="width:104px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h1&gt;!locks (!ntsdexts.locks)
&lt;/h1&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;中的&lt;strong&gt;!locks&lt;/strong&gt; 扩展命令显示当前进程关联的临界区(critical section)的清单。 
&lt;p&gt;该扩展命令不要和&lt;a&gt;&lt;strong&gt;!kdext*.locks&lt;/strong&gt;&lt;/a&gt; 命令混淆。
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!locks&lt;/strong&gt; [&lt;em&gt;Options&lt;/em&gt;] &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;em&gt;Options&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定要显示的信息数量。可以是下面这些选项的任意组合：
&lt;p style="margin-left:21pt"&gt;&lt;strong&gt;-v&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;显示所有临界区，包括当前没有被持有的那些。 
&lt;p style="margin-left:21pt"&gt;&lt;strong&gt;-o&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;&lt;em&gt;(Windows XP和之后)&lt;/em&gt; 仅显示孤立的信息(orphaned information)(没有指向合法的临界区的指针)。 
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:151px"&gt;&lt;col style="width:104px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;该扩展命令会显示所有通过调用&lt;strong&gt;RtlInitializeCriticalSection&lt;/strong&gt; 初始化的临界区。如果没有临界区，那么不会产生输出。
&lt;p style="margin-left:21pt"&gt;示例如下：
&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;0:000&amp;gt; &lt;strong&gt;!locks&lt;/strong&gt;&lt;br&gt;&lt;br&gt;CritSec w3svc!g_pWamDictator+a0 at 68C2C298&lt;br&gt;LockCount          0&lt;br&gt;RecursionCount     1&lt;br&gt;OwningThread       d1&lt;br&gt;EntryCount         1&lt;br&gt;ContentionCount    0&lt;br&gt;*** Locked&lt;br&gt;&lt;br&gt;CritSec SMTPSVC+66a30 at 67906A30&lt;br&gt;LockCount          0&lt;br&gt;RecursionCount     1&lt;br&gt;OwningThread       d0&lt;br&gt;EntryCount         1&lt;br&gt;ContentionCount    0&lt;br&gt;*** Locked&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;附加信息&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;关于可以显示临界区信息的其他命令和扩展命令，查看&lt;a&gt;显示临界区&lt;/a&gt;。关于临界区的信息，查看Microsoft Windows SDK文档、Windows Driver Kit (WDK)文档，以及Mark Russinovich 和David Solomon&lt;em&gt;
		&lt;/em&gt;编写的&lt;em&gt;Microsoft Windows Internals&lt;/em&gt;。
&lt;h1&gt;!runaway
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!runaway&lt;/strong&gt;扩展命令显示每个线程消费的时间。 
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!runaway&lt;/strong&gt; [&lt;em&gt;Flags&lt;/em&gt;] &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;em&gt;Flags&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定要显示哪些信息。&lt;em&gt;Flags&lt;/em&gt; 可以是下面这些位的任意组合。默认值为0x1： 
&lt;p style="margin-left:21pt"&gt;Bit 0 (0x1) 
&lt;p style="margin-left:21pt"&gt;让调试器显示每个线程消耗的用户模式时间(user time)。 
&lt;p style="margin-left:21pt"&gt;Bit 1 (0x2) 
&lt;p style="margin-left:21pt"&gt;显示每个线程消耗的内核时间(kernel time)。 
&lt;p style="margin-left:21pt"&gt;Bit 2 (0x4) 
&lt;p style="margin-left:21pt"&gt;显示每个线程从创建开始经历了多少时间。 
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:151px"&gt;&lt;col style="width:104px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Uext.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Uext.dll&lt;/em&gt;
							&lt;br&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Uext.dll&lt;/em&gt;
							&lt;br&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;p&gt;&lt;strong&gt;!runaway&lt;/strong&gt; 扩展命令只能在活动调试时，或者调试通过&lt;a&gt;&lt;strong&gt;.dump /mt&lt;/strong&gt;&lt;/a&gt; 或&lt;a&gt;&lt;strong&gt;.dump /ma&lt;/strong&gt;&lt;/a&gt;创建的dump文件时使用。
&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;该扩展命令可以用来快速找出哪些线程循环失去控制消耗了太多CPU时间。
&lt;p style="margin-left:21pt"&gt;输出中以调试器的内部线程号和16进制线程ID来标识每个线程。还会显示调试器ID。
&lt;p style="margin-left:21pt"&gt;下面是示例：
&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;&lt;br&gt;0:001&amp;gt; &lt;strong&gt;!runaway 7&lt;/strong&gt;&lt;br&gt;&lt;br&gt; User Mode Time&lt;br&gt; Thread       Time&lt;br&gt; 0:55c        0:00:00.0093&lt;br&gt; 1:1a4        0:00:00.0000&lt;br&gt;&lt;br&gt; Kernel Mode Time&lt;br&gt; Thread       Time&lt;br&gt; 0:55c        0:00:00.0140&lt;br&gt; 1:1a4        0:00:00.0000&lt;br&gt;&lt;br&gt; Elapsed Time&lt;br&gt; Thread       Time&lt;br&gt; 0:55c        0:00:43.0533&lt;br&gt; 1:1a4        0:00:25.0876&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;附加信息&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;关于用户模式下线程的信息，查看&lt;a&gt;控制进程和线程&lt;/a&gt;。关于对进程和线程进行分析的信息，查看Mark Russinovich 和David Solomon&lt;em&gt;
		&lt;/em&gt;编写的&lt;em&gt;Microsoft Windows Internals&lt;/em&gt;。
&lt;h1&gt;!threadtoken
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!threadtoken&lt;/strong&gt; 扩展命令显示当前线程的模拟状态(impersonation state)。
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!threadtoken&lt;/strong&gt; &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:151px"&gt;&lt;col style="width:104px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;&lt;strong&gt;!threadtoken&lt;/strong&gt; 扩展命令在Windows XP和之后版本中已经废除。使用&lt;a&gt;&lt;strong&gt;!token&lt;/strong&gt;&lt;/a&gt; 来替代。
&lt;p style="margin-left:21pt"&gt;如果当前线程处于模拟状态下(impersonating)，那么会显示它使用的令牌(token)。
&lt;p style="margin-left:21pt"&gt;否则，会出现&amp;quot;Thread is not impersonating&amp;quot;信息。并且显示进程的令牌。
&lt;p style="margin-left:21pt"&gt;令牌的显示的格式和使用&lt;strong&gt;!handle&lt;/strong&gt; 来显示令牌句柄时一样。
&lt;p style="margin-left:21pt"&gt;下面是示例：
&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;0:000&amp;gt; &lt;strong&gt;~&lt;/strong&gt;&lt;br&gt;.  0  id: 1d0.55c   Suspend: 1 Teb 7ffde000 Unfrozen&lt;br&gt;#  1  id: 1d0.1a4   Suspend: 1 Teb 7ffdd000 Unfrozen&lt;br&gt;&lt;br&gt;0:000&amp;gt; &lt;strong&gt;!threadtoken&lt;/strong&gt;&lt;br&gt;&lt;br&gt;***Thread is not impersonating, using process token***&lt;br&gt;    Auth Id    0 : 0x1c93d&lt;br&gt;    Type       Primary&lt;br&gt;    Imp Level  Anonymous&lt;br&gt;     Token Id  0 : 0x5e8c19&lt;br&gt;     Mod Id    0 : 0x5e8c12&lt;br&gt;     Dyn Chg   0x1f4&lt;br&gt;     Dyn Avail 0x1a4&lt;br&gt;     Groups    26&lt;br&gt;     Privs     17&lt;br&gt;     User      S-1-5-21-2127521184-1604012920-1887927527-74790&lt;br&gt;     Groups    26&lt;br&gt;               S-1-5-21-2127521184-1604012920-1887927527-513&lt;br&gt;               S-1-1-0&lt;br&gt;               S-1-5-32-544&lt;br&gt;               S-1-5-32-545&lt;br&gt;               S-1-5-21-2127521184-1604012920-1887927527-277551&lt;br&gt;               S-1-5-21-2127521184-1604012920-1887927527-211604&lt;br&gt;               S-1-5-21-2127521184-1604012920-1887927527-10546&lt;br&gt;               S-1-5-21-2127521184-1604012920-1887927527-246657&lt;br&gt;               S-1-5-21-2127521184-1604012920-1887927527-277552&lt;br&gt;               S-1-5-21-2127521184-1604012920-1887927527-416040&lt;br&gt;               S-1-5-21-2127521184-1604012920-1887927527-96548&lt;br&gt;               S-1-5-21-2127521184-1604012920-1887927527-262644&lt;br&gt;               S-1-5-21-2127521184-1604012920-1887927527-155802&lt;br&gt;               S-1-5-21-2127521184-1604012920-1887927527-158763&lt;br&gt;               S-1-5-21-2127521184-1604012920-1887927527-279132&lt;br&gt;               S-1-5-21-2127521184-1604012920-1887927527-443952&lt;br&gt;               S-1-5-21-2127521184-1604012920-1887927527-175772&lt;br&gt;               S-1-5-21-2127521184-1604012920-1887927527-388472&lt;br&gt;               S-1-5-21-2127521184-1604012920-1887927527-443950&lt;br&gt;               S-1-5-21-2127521184-1604012920-1887927527-266975&lt;br&gt;               S-1-5-21-2127521184-1604012920-1887927527-158181&lt;br&gt;               S-1-5-21-2127521184-1604012920-1887927527-279435&lt;br&gt;               S-1-5-5-0-116804&lt;br&gt;               S-1-2-0&lt;br&gt;               S-1-5-4&lt;br&gt;               S-1-5-11&lt;br&gt;     Privileges    17&lt;br&gt;               SeUndockPrivilege ( Enabled Default )&lt;br&gt;               SeTakeOwnershipPrivilege ( )&lt;br&gt;               SeShutdownPrivilege ( )&lt;br&gt;               SeDebugPrivilege ( )&lt;br&gt;               SeIncreaseBasePriorityPrivilege ( )&lt;br&gt;               SeAuditPrivilege ( )&lt;br&gt;               SeSyncAgentPrivilege ( )&lt;br&gt;               SeLoadDriverPrivilege ( )&lt;br&gt;               SeSystemEnvironmentPrivilege ( Enabled )&lt;br&gt;               SeRemoteShutdownPrivilege ( )&lt;br&gt;               SeProfileSingleProcessPrivilege ( )&lt;br&gt;               SeCreatePagefilePrivilege ( )&lt;br&gt;               SeCreatePermanentPrivilege ( )&lt;br&gt;               SeSystemProfilePrivilege ( Enabled )&lt;br&gt;               SeBackupPrivilege ( )&lt;br&gt;               SeMachineAccountPrivilege ( )&lt;br&gt;               SeEnableDelegationPrivilege ( Enabled )&lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;附加信息&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;关于线程和模拟的信息，查看线程和模拟(impersonation)的信息，查看Microsoft Windows SDK 文档，以及Mark Russinovich 和David Solomon&lt;em&gt;
		&lt;/em&gt;编写的&lt;em&gt;Microsoft Windows Internals&lt;/em&gt;。
&lt;h1&gt;!uniqstack
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!uniqstack&lt;/strong&gt; 扩展命令显示当前进程中所有线程的调用堆栈，除开重复的那些。 
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!uniqstack&lt;/strong&gt; [ &lt;strong&gt;b | v | p &lt;/strong&gt;] [ &lt;strong&gt;n &lt;/strong&gt;]&lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;strong&gt;b&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;显示中包含传递给每个函数的前3个参数。 
&lt;p&gt;&lt;strong&gt;v&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;显示帧指针省略信息(frame pointer omission (FPO) information)。在x86处理器上，还会显示调用约定的信息。 
&lt;p&gt;&lt;strong&gt;p&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;显示调用堆栈中每个函数的完整参数。会列出每个参数的数据类型、名字和值。&lt;em&gt;需要完整符号信息&lt;/em&gt;。 
&lt;p&gt;&lt;strong&gt;n&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;显示帧序号(frame number)。 
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:151px"&gt;&lt;col style="width:104px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Uext.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Uext.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Uext.dll&lt;/em&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;除了不显示重复的调用堆栈之外，该命令和&lt;a&gt;&lt;strong&gt;k, kb, kd, kp, kP, kv &lt;/strong&gt;(Display Stack Backtrace)&lt;/a&gt; 命令类似。 
&lt;p style="margin-left:21pt"&gt;例如：
&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;0:000&amp;gt; &lt;strong&gt;!uniqstack&lt;/strong&gt;&lt;br&gt;Processing 14 threads, please wait&lt;br&gt;&lt;br&gt;.  0  Id: f0f0f0f0.15c Suspend: 1 Teb: 00000000`7fff8000 Unfrozen&lt;br&gt;      Priority: 0&lt;br&gt;Child-SP          Child-BSP         RetAddr           Call Site&lt;br&gt;00000000`0006e5e0 00000000`00070420 00000000`6b009840 wow64!Wow64NotifyDebugger+0x40 [d:\xpclient\base\wow64\wow64\wow64.c @ 581]&lt;br&gt;00000000`0006e600 00000000`000703d0 00000000`6b03db00 wow64!Wow64KiRaiseException+0x1a0 [d:\xpclient\base\wow64\wow64\wow64.c @ 649]&lt;br&gt;00000000`0006e950 00000000`000703b0 00000000`6b008520 wow64!whNtRaiseException+0x40&lt;br&gt;00000000`0006e950 00000000`00070368 00000000`6b1845e0 wow64!Wow64SystemService+0x220 [d:\xpclient\base\wow64\wow64\wow64.c @ 1100]&lt;br&gt;00000000`0006e9b0 00000000`00070310 00000000`6b009980 wow64cpu!CpuSimulate+0x3a0 [d:\xpclient\base\wow64\cpu\ia64\cpu\cpumain.c @ 730]&lt;br&gt;00000000`0006e9d0 00000000`000702d0 00000000`6b009ff0 wow64!RunCpuSimulation+0x60 [d:\xpclient\base\wow64\wow64\wow64.c @ 1168]&lt;br&gt;00000000`0006e9e0 00000000`00070248 00000000`77ea4a10 wow64!Wow64LdrpInitialize+0x5d0 [d:\xpclient\base\wow64\wow64\wow64.c @ 248]&lt;br&gt;00000000`0006f290 00000000`000700e0 00000000`77ea5d60 ntdll!LdrpInitializeProcess+0x2150 [d:\xpclient\base\ntdll\ldrinit.c @ 1817]&lt;br&gt;00000000`0006f4c0 00000000`00070028 00000000`77ed6000 ntdll!LdrpInitialize+0x560 [d:\xpclient\base\ntdll\ldrinit.c @ 553]&lt;br&gt;00000000`0006f550 00000000`00070000 00000000`77ed9000 ntdll!LdrInitializeThunk+0x20 [D:\xpclient\base\ntdll\daytona\..\ia64\ldrthunk.s @ 80]&lt;br&gt;00000000`0006f550 00000000`00070000 00000000`77ca78a0 ntdll!KiUserApcDispatch+0x50 [D:\xpclient\base\ntos\rtl\user\..\ia64\trampoln.s @ 203]&lt;br&gt;00000000`0006fff0 00000000`00070000 00000000`00000000 0x77ca78a0&lt;br&gt;&lt;br&gt;.  1  Id: f0f0f0f0.718 Suspend: 1 Teb: 00000000`7fff4000 Unfrozen&lt;br&gt;      Priority: 0&lt;br&gt;Child-SP          Child-BSP         RetAddr           Call Site&lt;br&gt;00000000`0043eb50 00000000`00440250 00000000`6b008520 wow64!whNtDelayExecution+0x150 [d:\xpclient\base\wow64\whnt32\obj\ia64\whnt32.c @ 24541]&lt;br&gt;00000000`0043eb80 00000000`00440208 00000000`6b1845e0 wow64!Wow64SystemService+0x220 [d:\xpclient\base\wow64\wow64\wow64.c @ 1100]&lt;br&gt;00000000`0043ebe0 00000000`004401a8 00000000`6b009980 wow64cpu!CpuSimulate+0x3a0 [d:\xpclient\base\wow64\cpu\ia64\cpu\cpumain.c @ 730]&lt;br&gt;00000000`0043ec00 00000000`00440168 00000000`6b009ff0 wow64!RunCpuSimulation+0x60 [d:\xpclient\base\wow64\wow64\wow64.c @ 1168]&lt;br&gt;00000000`0043ec10 00000000`004400e0 00000000`77ea5f50 wow64!Wow64LdrpInitialize+0x5d0 [d:\xpclient\base\wow64\wow64\wow64.c @ 248]&lt;br&gt;00000000`0043f4c0 00000000`00440028 00000000`77ed6000 ntdll!LdrpInitialize+0x750 [d:\xpclient\base\ntdll\ldrinit.c @ 626]&lt;br&gt;00000000`0043f550 00000000`00440000 00000000`77ed9000 ntdll!LdrInitializeThunk+0x20 [D:\xpclient\base\ntdll\daytona\..\ia64\ldrthunk.s @ 80]&lt;br&gt;00000000`0043f550 00000000`00440000 00000000`7de05690 ntdll!KiUserApcDispatch+0x50 [D:\xpclient\base\ntos\rtl\user\..\ia64\trampoln.s @ 203]&lt;br&gt;00000000`0043fff0 00000000`00440000 00000000`00000000 kernel32!MulDiv+0x110 [D:\xpclient\base\win32\client\i386\critsect.asm @ 550]&lt;br&gt;&lt;br&gt;. 13  Id: f0f0f0f0.494 Suspend: 1 Teb: 00000000`7ef98000 Unfrozen&lt;br&gt;      Priority: 0&lt;br&gt;Child-SP          Child-BSP         RetAddr           Call Site&lt;br&gt;00000000`00feffe0 00000000`00ff0040 00000000`77e94f30 ntdll!DbgBreakPoint+0x10 [D:\xpclient\base\ntos\rtl\user\..\ia64\debugstb.s @ 66]&lt;br&gt;00000000`00feffe0 00000000`00ff0040 00000000`00000000 ntdll!DbgUiRemoteBreakin+0x90 [d:\xpclient\base\ntdll\dlluistb.c @ 269]&lt;br&gt;&lt;br&gt;Total threads: 14&lt;br&gt;Duplicate callstacks: 11 (windbg thread #s follow):&lt;br&gt;2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;附加信息&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;关于堆栈回溯的更多信息和其它显示调用堆栈的方法，查看&lt;a&gt;查看调用堆栈&lt;/a&gt;。 
&lt;h1&gt;!vadump
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!vadump&lt;/strong&gt; 扩展命令显示所有的虚拟内存区域以及它们对应的保护信息。
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!vadump&lt;/strong&gt; [&lt;strong&gt;-v&lt;/strong&gt;] &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;strong&gt;-v&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;显示中还包含每个原始分配区域(original allocation region)的信息。由于每个区域中的不同地址在分配之后可能改变成了自己的保护属性(例如使用&lt;strong&gt;VirtualProtect&lt;/strong&gt;)，所以大区域的原始保护属性可能和内部的子区域不一样。 
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:151px"&gt;&lt;col style="width:104px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Uext.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Uext.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Uext.dll&lt;/em&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;下面是示例：
&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;0:000&amp;gt; &lt;strong&gt;!vadump&lt;/strong&gt;&lt;br&gt;BaseAddress:       00000000&lt;br&gt;RegionSize:        00010000&lt;br&gt;State:             00010000  MEM_FREE&lt;br&gt;Protect:           00000001  PAGE_NOACCESS&lt;br&gt;&lt;br&gt;BaseAddress:       00010000&lt;br&gt;RegionSize:        00001000&lt;br&gt;State:             00001000  MEM_COMMIT&lt;br&gt;Protect:           00000004  PAGE_READWRITE&lt;br&gt;Type:              00020000  MEM_PRIVATE&lt;br&gt;.........&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;输出重，State 行显示从BaseAddress 开始的内存范围的状态。可能的状态值有MEM_COMMIT、MEM_FREE和MEM_RESERVE。&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;Protect 行显示内存区域的保护状态。可能的值有PAGE_NOACCESS、PAGE_READONLY、PAGE_READWRITE、PAGE_EXECUTE、PAGE_EXECUTE_READ、PAGE_EXECUTE_READWRITE、PAGE_WRITECOPY、PAGE_EXECUTE_WRITECOPY和PAGE_GUARD。
&lt;p style="margin-left:21pt"&gt;Type 行显示内存种类。可能的值有MEM_IMAGE、MEM_MAPPED和MEM_PRIVATE。
&lt;p style="margin-left:21pt"&gt;下面是使用&lt;strong&gt;-v&lt;/strong&gt;参数的示例：
&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;0:000&amp;gt; &lt;strong&gt;!vadump -v&lt;/strong&gt;&lt;br&gt;BaseAddress:       00000000&lt;br&gt;AllocationBase:    00000000&lt;br&gt;RegionSize:        00010000&lt;br&gt;State:             00010000  MEM_FREE&lt;br&gt;Protect:           00000001  PAGE_NOACCESS&lt;br&gt;&lt;br&gt;BaseAddress:       00010000&lt;br&gt;AllocationBase:    00010000&lt;br&gt;AllocationProtect: 00000004  PAGE_READWRITE&lt;br&gt;RegionSize:        00001000&lt;br&gt;State:             00001000  MEM_COMMIT&lt;br&gt;Protect:           00000004  PAGE_READWRITE&lt;br&gt;Type:              00020000  MEM_PRIVATE&lt;br&gt;.........&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;使用&lt;strong&gt;-v&lt;/strong&gt;时，AllocationProtect行显示整个区域被创建时的默认保护属性。Protect行显示指定地址处实际的保护属性。&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;h4&gt;附加信息
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;要查看单个虚拟地址的内存保护信息，可以使用&lt;a&gt;&lt;strong&gt;!vprot&lt;/strong&gt;&lt;/a&gt;。关于内存保护的信息，查看Mark Russinovich 和David Solomon&lt;em&gt;
		&lt;/em&gt;编写的&lt;em&gt;Microsoft Windows Internals&lt;/em&gt;。
&lt;h1&gt;!vprot
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!vprot&lt;/strong&gt; 扩展命令显示虚拟内存保护信息。
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!vprot&lt;/strong&gt; [&lt;em&gt;Address&lt;/em&gt;] &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;em&gt;Address&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定要查看内存保护状态的16进制地址。
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:151px"&gt;&lt;col style="width:104px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Uext.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Uext.dll&lt;/em&gt;
							&lt;br&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Uext.dll&lt;/em&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;&lt;strong&gt;!vprot&lt;/strong&gt; 扩展命令可以用于活动调试和dump文件调试。 
&lt;p style="margin-left:21pt"&gt;下面是示例：
&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;0:000&amp;gt; &lt;strong&gt;!vprot 30c191c&lt;/strong&gt;&lt;br&gt;BaseAddress: 030c1000&lt;br&gt;AllocationBase: 030c0000&lt;br&gt;AllocationProtect: 00000080 PAGE_EXECUTE_WRITECOPY&lt;br&gt;RegionSize: 00011000&lt;br&gt;State: 00001000 MEM_COMMIT&lt;br&gt;Protect: 00000010 PAGE_EXECUTE&lt;br&gt;Type: 01000000 MEM_IMAGE&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;输出中， AllocationProtect 行显示整个区域被创建时设置的默认保护属性。注意该区域中各个单独的地址可能在之后更改了保护属性(例如调用了&lt;strong&gt;VirtualProtect&lt;/strong&gt;)。Protect行显示指定地址处实际的保护属性。保护属性的值有PAGE_NOACCESS、PAGE_READONLY、PAGE_READWRITE、PAGE_EXECUTE、 PAGE_EXECUTE_READ、PAGE_EXECUTE_READWRITE、PAGE_WRITECOPY、PAGE_EXECUTE_WRITECOPY和 PAGE_GUARD。&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;State行对应传递给 &lt;strong&gt;!vprot&lt;/strong&gt; 的虚拟地址。可能的状态有MEM_COMMIT、MEM_FREE、和MEM_RESERVE。
&lt;p style="margin-left:21pt"&gt;Type行显示内存类型。可能的值有MEM_IMAGE、MEM_MAPPED和 MEM_PRIVATE。
&lt;h4&gt;附加信息
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;要查看目标进程拥有的所有内存区域的保护信息，可以使用&lt;a&gt;&lt;strong&gt;!vadump&lt;/strong&gt;&lt;/a&gt;。关于内存保护的信息，查看Mark Russinovich 和David Solomon&lt;em&gt;
		&lt;/em&gt;编写的&lt;em&gt;Microsoft Windows Internals&lt;/em&gt;。&lt;img src="http://c.services.spaces.live.com/CollectionWebService/c.gif?cid=-5341356082337814461&amp;page=RSS%3a+WinDbg+%e6%96%87%e6%a1%a3%e7%bf%bb%e8%af%91----91&amp;referrer=" width="1px" height="1px" border="0" alt=""&gt;&lt;img style="position:absolute" alt="" width="0px" height="0px" src="http://c.live.com/c.gif?NC=31263&amp;amp;NA=1149&amp;amp;PI=73329&amp;amp;RF=&amp;amp;DI=3919&amp;amp;PS=85545&amp;amp;TP=netroc682.spaces.live.com&amp;amp;GT1=netroc682"&gt;</description><category>None</category><comments>http://netroc682.spaces.live.com/Blog/cns!B5DFB0F15D61E843!312.entry#comment</comments><guid isPermaLink="true">http://netroc682.spaces.live.com/Blog/cns!B5DFB0F15D61E843!312.entry</guid><pubDate>Mon, 18 Aug 2008 03:24:19 GMT</pubDate><slash:comments>0</slash:comments><msn:type>blogentry</msn:type><live:type>blogentry</live:type><live:typelabel>Blog entry</live:typelabel><wfw:commentRss>http://netroc682.spaces.live.com/blog/cns!B5DFB0F15D61E843!312/comments/feed.rss</wfw:commentRss><wfw:comment>http://netroc682.spaces.live.com/Blog/cns!B5DFB0F15D61E843!312.entry#comment</wfw:comment><dcterms:modified>2008-08-18T03:24:19Z</dcterms:modified></item><item><title>WinDbg 文档翻译----90</title><link>http://netroc682.spaces.live.com/Blog/cns!B5DFB0F15D61E843!311.entry</link><description>&lt;p&gt;&lt;span style="font-family:宋体;font-size:10pt"&gt;cc682/NetRoc
&lt;/span&gt;&lt;p&gt;&lt;a href="http://netroc682.spaces.live.com/"&gt;&lt;span style="font-family:宋体;font-size:10pt"&gt;http://netroc682.spaces.live.com/&lt;/span&gt;&lt;/a&gt;
	&lt;h1&gt;用户模式扩展命令
&lt;/h1&gt;&lt;p&gt;本小节中的参考用于描述主要在用户模式调试时使用的扩展命令。
&lt;p&gt;调试器会自动加载这些扩展命令的适当版本。如果不是自己已经加载了一个不同的版本，那么就不需要关心所使用的DLL版本。查看&lt;a&gt;使用调试器扩展命令&lt;/a&gt;获得默认模块搜索顺序的说明。查看&lt;a&gt;加载调试器扩展DLL&lt;/a&gt;获得关于加载扩展模块的说明。
&lt;p&gt;每个扩展命令的参考部分都列出了导出该命令的DLL。可以用下面的规则来判断扩展DLL是从什么地方加载的：
&lt;ul&gt;&lt;li&gt;目标程序运行在Windows NT 4.0发行版上，使用的是&lt;em&gt;nt4fre\Ntsdexts.dll&lt;/em&gt;。
&lt;li&gt;目标程序运行在Windows NT 4.0 checked版上，使用&lt;em&gt;nt4chk\Ntsdexts.dll&lt;/em&gt;。
&lt;li&gt;目标程序运行在Windows 2000 发行版商，使用&lt;em&gt;w2kfre\Ntsdexts.dll&lt;/em&gt;。
&lt;li&gt;目标程序运行于Windows 2000 checked版本上，使用&lt;em&gt;w2kchk\Ntsdexts.dll&lt;/em&gt;。
&lt;li&gt;目标程序运行于Windows XP和之后版本中时，使用 &lt;em&gt;winxp\Ntsdexts.dll&lt;/em&gt;。
&lt;/ul&gt;&lt;p&gt;另外，和操作系统不相关的那些用户模式扩展放在&lt;em&gt;winext\Uext.dll&lt;/em&gt;中。
&lt;h1&gt;!avrf
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!avrf&lt;/strong&gt;扩展用于控制&lt;a&gt;Application Verifier&lt;/a&gt;的设置，并且显示由Application Verifier产生的各种输出。
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!avrf&lt;/strong&gt; &lt;br&gt;&lt;strong&gt;!avrf -a&lt;/strong&gt; &lt;em&gt;Address&lt;/em&gt; &lt;br&gt;&lt;strong&gt;!avrf -cs&lt;/strong&gt; { &lt;em&gt;Length&lt;/em&gt; | &lt;strong&gt;-a&lt;/strong&gt; &lt;em&gt;Address&lt;/em&gt; } &lt;br&gt;&lt;strong&gt;!avrf -hp&lt;/strong&gt; { &lt;em&gt;Length&lt;/em&gt; | &lt;strong&gt;-a&lt;/strong&gt; &lt;em&gt;Address&lt;/em&gt; } &lt;br&gt;&lt;strong&gt;!avrf -vs&lt;/strong&gt; { &lt;em&gt;Length&lt;/em&gt; | &lt;strong&gt;-a&lt;/strong&gt; &lt;em&gt;Address&lt;/em&gt; } &lt;br&gt;&lt;strong&gt;!avrf -dlls&lt;/strong&gt; [ &lt;em&gt;Length&lt;/em&gt; ] &lt;br&gt;&lt;strong&gt;!avrf -ex&lt;/strong&gt; [ &lt;em&gt;Length&lt;/em&gt; ] &lt;br&gt;&lt;strong&gt;!avrf -cnt&lt;/strong&gt; &lt;br&gt;&lt;strong&gt;!avrf -trm&lt;/strong&gt; &lt;br&gt;&lt;strong&gt;!avrf -threads&lt;/strong&gt; [&lt;em&gt;ThreadID&lt;/em&gt;] &lt;br&gt;&lt;strong&gt;!avrf -trace&lt;/strong&gt; &lt;em&gt;TraceIndex&lt;/em&gt; &lt;br&gt;&lt;strong&gt;!avrf -brk&lt;/strong&gt; [&lt;em&gt;BreakEventType&lt;/em&gt;] &lt;br&gt;&lt;strong&gt;!avrf -flt&lt;/strong&gt; &lt;br&gt;&lt;strong&gt;!avrf -flt&lt;/strong&gt; &lt;em&gt;EventType&lt;/em&gt; &lt;em&gt;Probability&lt;/em&gt; &lt;br&gt;&lt;strong&gt;!avrf -flt break&lt;/strong&gt; &lt;em&gt;EventType&lt;/em&gt; &lt;br&gt;&lt;strong&gt;!avrf -flt stacks&lt;/strong&gt; &lt;em&gt;Length&lt;/em&gt; &lt;br&gt;&lt;strong&gt;!avrf -trg&lt;/strong&gt; [ &lt;em&gt;Start End&lt;/em&gt; | &lt;strong&gt;dll&lt;/strong&gt; &lt;em&gt;Module&lt;/em&gt; | &lt;strong&gt;all&lt;/strong&gt; ] &lt;br&gt;&lt;strong&gt;!avrf -skp&lt;/strong&gt; [ &lt;em&gt;Start End&lt;/em&gt; | &lt;strong&gt;dll&lt;/strong&gt; &lt;em&gt;Module&lt;/em&gt; | &lt;strong&gt;all&lt;/strong&gt; | &lt;em&gt;Time&lt;/em&gt; ] &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;strong&gt;-a&lt;/strong&gt;
		&lt;em&gt;Address&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定一个地址。会显示包含这个地址的内存分配记录、以这个地址为开始的内存释放操作记录。如果该选项前面没有 &lt;strong&gt;–cs&lt;/strong&gt;、 &lt;strong&gt;-hp&lt;/strong&gt;或者 &lt;strong&gt;–vs&lt;/strong&gt;，那么会搜索light heap。
&lt;p&gt;&lt;strong&gt;-cs&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;显示临界区(critical section)的删除日志。详细信息查看Application Verifier 文档中的&amp;quot;Critical Section Delete Logs&amp;quot;。 
&lt;p&gt;&lt;strong&gt;-hp&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;显示堆操作日志。详细信息查看Application Verifier 文档中的&amp;quot;Heap Operation Logs&amp;quot;。 
&lt;p&gt;&lt;strong&gt;-vs&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;显示虚拟地址空间(virtual space)操作日志。详细信息，查看Application Verifier 文档中的&amp;quot;Virtual Space Operation Logs&amp;quot;。
&lt;p&gt;&lt;strong&gt;-dlls&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;显示DLL的加载/卸载日志。详细信息查看Application Verifier 文档中的&amp;quot;DLL Load/Unload Logs&amp;quot;。
&lt;p&gt;&lt;strong&gt;-ex&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;显示异常日志。详细信息查看Application Verifier 文档中的&amp;quot;Exception Logs&amp;quot;。
&lt;p&gt;&lt;em&gt;Length&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定要显示的记录数量。如果使用了&lt;strong&gt;-dlls&lt;/strong&gt; 或者&lt;strong&gt;-ex&lt;/strong&gt; 选项，则可以省略&lt;em&gt;Length&lt;/em&gt;来显示所有的DLL 加载/卸载操作或者所有异常记录。 
&lt;p&gt;&lt;strong&gt;-cnt&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;显示全局计数器(global counter)的清单。
&lt;p&gt;&lt;strong&gt;-trm&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;显示所有终止和挂起线程的日志。 
&lt;p&gt;&lt;strong&gt;-threads&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;显示目标进程中线程的信息。对于子线程，还会显示堆栈大小和由父线程指定的&lt;strong&gt;CreateThread&lt;/strong&gt; 标志。
&lt;p&gt;&lt;em&gt;ThreadID&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定要显示的线程ID。省略时显示所有线程。 
&lt;p&gt;&lt;strong&gt;-trace &lt;/strong&gt;&lt;em&gt;TraceIndex&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;显示指定的&lt;em&gt;TraceIndex&lt;/em&gt; 的调用堆栈。一些结构用到了这个16位索引来标识调用堆栈。这个索引指向调用堆栈数据库(stack trace database)中的位置。如果正在分析这样的结构，那么这个选项非常有用。 
&lt;p&gt;&lt;strong&gt;-brk&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;表明这是一个break-event命令。不带参数适用 &lt;strong&gt;!avrf -brk&lt;/strong&gt; 时，会显示break event设置。可以在 文档的 &amp;quot;Requesting Breaks on Certain Events&amp;quot; 中查看示例。
&lt;p&gt;&lt;em&gt;BreakEventType&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定break event 的type number 。查看Application Verifier 文档的&amp;quot;Requesting Breaks on Certain Events&amp;quot;获得可用type的列表。 
&lt;p&gt;&lt;strong&gt;-flt&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;表示这是一个fault-injection 命令。不带参数使用&lt;strong&gt;!avrf –flt&lt;/strong&gt;时，显示当前的fault injection 设置。查看Application Verifier 文档中的&amp;quot;Choosing Which Events to Fault&amp;quot;获得示例。
&lt;p&gt;&lt;em&gt;EventType&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定event的type number。查看Application Verifier 文档中的&amp;quot;Choosing Which Events to Fault&amp;quot;获得可能的type的列表。 
&lt;p&gt;&lt;em&gt;Probability&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定该event将会失败的频率。可以是从0到100(0x64)之间的任意整数。 
&lt;p&gt;&lt;strong&gt;break&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;让每次该fault 被inject时，Application Verifier 都中断到调试器中。这种中断的示例，查看Application Verifier 文档中的&amp;quot;Choosing Which Events to Fault&amp;quot;。
&lt;p&gt;&lt;strong&gt;stacks&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;显示最近一次fault-injected 操作的调用堆栈。查看Application Verifier 文档的&amp;quot;Choosing Which Events to Fault&amp;quot;获得示例。
&lt;p&gt;&lt;strong&gt;-trg&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;表明这是一个target range 命令。 不带参属使用 &lt;strong&gt;–trg&lt;/strong&gt;时，显示当前的target range。详细信息查看Application Verifier 文档中的&amp;quot;Choosing Where to Fault&amp;quot;。
&lt;p&gt;&lt;strong&gt;-skp&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;表示这是一个exclusion range 命令。不带参数使用&lt;strong&gt;-trg&lt;/strong&gt;时，显示当前的target range。详细信息查看Application Verifier 文档中的&amp;quot;Choosing Where to Fault&amp;quot;。 
&lt;p&gt;&lt;em&gt;Start&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定target range 或者exclusion range 的开始地址。 
&lt;p&gt;&lt;em&gt;End&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定target range 或者exclusion range 的结束地址。 
&lt;p&gt;&lt;em&gt;Module&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定要targeted 或者excluded 的模块名。&lt;em&gt;Module&lt;/em&gt;是完整的模块名，包括&lt;em&gt;.exe&lt;/em&gt; 或&lt;em&gt;.dll&lt;/em&gt; 扩展名。不能含有路径信息。 
&lt;p&gt;&lt;strong&gt;all&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;使得所有的target range或者exclusion range重置。 
&lt;p&gt;&lt;em&gt;Time&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;恢复执行后的&lt;em&gt;Time&lt;/em&gt;毫秒内消除任何fault。 
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:151px"&gt;&lt;col style="width:123px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Exts.dll&lt;/em&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;p&gt;
 &lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;不带参数使用&lt;strong&gt;!avrf&lt;/strong&gt; 扩展时，会显示当前的Application Verifier选项。如果已经启用了&lt;strong&gt;Full page heap&lt;/strong&gt; 或者&lt;strong&gt;Fast fill heap&lt;/strong&gt;选项，那么还会显示active page heap的信息。查看Application Verifier 文档中的 &amp;quot;Heap Operation Logs&amp;quot;获得示例。
&lt;p style="margin-left:21pt"&gt;如果发生了Application Verifier Stop，不带参数的&lt;strong&gt;!avrf&lt;/strong&gt; 扩展会显示停止的类型以及原因。查看Application Verifier 文档中的&amp;quot;Debugging Application Verifier Stops&amp;quot; 获得示例。
&lt;p style="margin-left:21pt"&gt;如果没有&lt;em&gt;ntdll.dll&lt;/em&gt; 和&lt;em&gt;verifier.dll&lt;/em&gt; 的符号，那么&lt;strong&gt;!avrf&lt;/strong&gt; 扩展会产生错误信息。关于如何定位这种问题的信息，查看Application Verifier 文档中的&amp;quot;Setting Up a Debugger for Application Verifier&amp;quot;。
&lt;h4&gt;附加信息
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;关于如何下载和安装Application Verifier ，以及它的文档的信息，查看&lt;a&gt;Application Verifier&lt;/a&gt;。
&lt;h1&gt;!critsec
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!critsec&lt;/strong&gt; 扩展命令显示某个临界区(critical section)。
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!critsec&lt;/strong&gt; &lt;em&gt;Address&lt;/em&gt; &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;em&gt;Address&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定临界区的16进制地址。 
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:151px"&gt;&lt;col style="width:123px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;如果不知道该临界区的地址，可以使用&lt;a&gt;&lt;strong&gt;!ntsdexts.locks&lt;/strong&gt;&lt;/a&gt; 扩展。它会显示由调用&lt;strong&gt;RtlInitializeCriticalSection&lt;/strong&gt; 来初始化的所有临界区。
&lt;p style="margin-left:21pt"&gt;下面是示例：
&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;0:000&amp;gt; &lt;strong&gt;!critsec 3a8c0e9c&lt;/strong&gt;&lt;br&gt;&lt;br&gt;CritSec +3a8c0e9c at 3A8C0E9C&lt;br&gt;LockCount          1&lt;br&gt;RecursionCount     1&lt;br&gt;OwningThread       99&lt;br&gt;EntryCount         472&lt;br&gt;ContentionCount    1&lt;br&gt;*** Locked&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;附加信息&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;关于其他可以显示临界区信息的命令，查看&lt;a&gt;显示临界区&lt;/a&gt;。关于临界区的信息，查看Microsoft Windows SDK文档、Windows Driver Kit (WDK) 文档，以及Mark Russinovich 和David Solomon&lt;em&gt;
		&lt;/em&gt;编写的&lt;em&gt;Microsoft Windows Internals&lt;/em&gt;。
&lt;h1&gt;!dp (!ntsdexts.dp)
&lt;/h1&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;中的&lt;strong&gt;!dp&lt;/strong&gt; 扩展命令显示一个CSR进程。 
&lt;p&gt;不要将该命令和&lt;a&gt;&lt;strong&gt;dp (Display Memory)&lt;/strong&gt;&lt;/a&gt; 命令或者 &lt;a&gt;&lt;strong&gt;!kdext*.dp&lt;/strong&gt;&lt;/a&gt;扩展命令混淆。
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!dp&lt;/strong&gt; [&lt;strong&gt;v&lt;/strong&gt;] [ &lt;em&gt;PID&lt;/em&gt; | &lt;em&gt;CSR-Process&lt;/em&gt; ]&lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;strong&gt;v&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;详细模式。显示中包含结构和线程列表。 
&lt;p&gt;&lt;em&gt;PID&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定CSR进程的进程ID。 
&lt;p&gt;&lt;em&gt;CSR-Process&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定CSR进程的16进制地址。 
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:151px"&gt;&lt;col style="width:123px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;该命令会显示进程地址、进程ID、序号(sequence number)、标志(flags)和引用计数。如果选择了详细模式，还会显示更多细节以及每个进程的线程信息。
&lt;p style="margin-left:21pt"&gt;如果没有指定进程，则会显示所有进程。
&lt;h4&gt;参见
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;&lt;a&gt;&lt;strong&gt;!dt&lt;/strong&gt;&lt;/a&gt;
	&lt;h1&gt;!dphdump
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!dphdump&lt;/strong&gt; 扩展命令显示debug page heap。
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!dphdump&lt;/strong&gt; &lt;em&gt;Address&lt;/em&gt; &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;em&gt;Address&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定堆的基地址或者堆句柄。 
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:151px"&gt;&lt;col style="width:123px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;如果在Windows 2000(Service Pack 1或之后)、Windows XP或之后版本Windows中查看page heap，应该使用&lt;a&gt;&lt;strong&gt;!heap&lt;/strong&gt;&lt;/a&gt; 扩展命令。
&lt;h4&gt;参见
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;&lt;a&gt;&lt;strong&gt;!dphfind&lt;/strong&gt;&lt;/a&gt;, &lt;a&gt;&lt;strong&gt;!dphflags&lt;/strong&gt;&lt;/a&gt;, &lt;a&gt;&lt;strong&gt;!dphhogs&lt;/strong&gt;&lt;/a&gt;
	&lt;h1&gt;!dphfind
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!dphfind&lt;/strong&gt; 扩展命令查找包含指定地址的debug page heap。 
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!dphfind&lt;/strong&gt; &lt;em&gt;Address&lt;/em&gt; &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;em&gt;Address&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定debug page heap必须包含的16进制地址。 
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:151px"&gt;&lt;col style="width:123px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;&lt;em&gt;Address&lt;/em&gt;一般是应用程序尝试访问从debug page heap中分配的内存时出错的地址。
&lt;p style="margin-left:21pt"&gt;如果在Windows 2000(Service Pack 1或之后)、Windows XP或之后版本Windows中查看page heap，应该使用&lt;a&gt;&lt;strong&gt;!heap&lt;/strong&gt;&lt;/a&gt; 扩展命令。
&lt;h4&gt;参见
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;&lt;a&gt;&lt;strong&gt;!dphdump&lt;/strong&gt;&lt;/a&gt;, &lt;a&gt;&lt;strong&gt;!dphflags&lt;/strong&gt;&lt;/a&gt;, &lt;a&gt;&lt;strong&gt;!dphhogs&lt;/strong&gt;&lt;/a&gt;
	&lt;h1&gt;!dphflags
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!dphflags&lt;/strong&gt; 扩展命令显示或设置global page heap flags。
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!dphflags&lt;/strong&gt; [&lt;em&gt;FLAGS&lt;/em&gt;] &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;em&gt;FLAGS&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;可以是下面这些位的任意组合： 
&lt;p style="margin-left:21pt"&gt;Bit 0 (0x1) 
&lt;p style="margin-left:21pt"&gt;使得调试器启用page heap。(99%的情况下都会希望设置这一位。如果为0，则使用标准堆。) 
&lt;p style="margin-left:21pt"&gt;Bit 1 (0x2) 
&lt;p style="margin-left:21pt"&gt;使得调试器搜集调用堆栈。(一般只在checked build上面才会设置。) 
&lt;p style="margin-left:21pt"&gt;Bit 2 (0x4) 
&lt;p style="margin-left:21pt"&gt;让调试器最小化对内存的影响。
&lt;p style="margin-left:21pt"&gt;Bit 3 (0x8) 
&lt;p style="margin-left:21pt"&gt;指定最小化(minimization)方法。如果设置了这一位，最小化是随机进行的。如果为0，则基于大小范围(size range)进行最小化。(如果没有设置bit 2(0x4)，则这个设置被忽略。) 
&lt;p style="margin-left:21pt"&gt;Bit 4 (0x10) 
&lt;p style="margin-left:21pt"&gt;让调试器捕获反向溢出(backward overrun)。 
&lt;p style="margin-left:21pt"&gt;Bits 15 to 8 
&lt;p style="margin-left:21pt"&gt;指定可用内存的百分比(相对于总内存)，低于可以从标准堆中进行分配的大小。仅当设置了bit 2(0x4)时起效。
&lt;p style="margin-left:21pt"&gt;Bits 31 to 16 
&lt;p style="margin-left:21pt"&gt;指定在page heap中分配的机率。只有当bit 2(0x4)和bit 3(0x8)设置时起效。需要指定两个大小：小一点的位于bit 31到bit 24，大一点的在bit 23到bit 16。大小处于这两个值之间的内存分配将从page heap中分配。
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:151px"&gt;&lt;col style="width:123px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;如果在Windows 2000(Service Pack 1或之后)、Windows XP或之后版本Windows中查看page heap，应该使用&lt;a&gt;&lt;strong&gt;!heap&lt;/strong&gt;&lt;/a&gt; 扩展命令。
&lt;p style="margin-left:21pt"&gt;这里有一些示例。下面的命令在free build上启用调用堆栈的搜集。(默认情况下不会)：
&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;&lt;strong&gt;!dphflags 0x03&lt;/strong&gt;&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;下面的命令将不可访问的页面放到分配(allocation)的开始位置。并且启用调用堆栈的跟踪：&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;&lt;strong&gt;!dphflags 0x13&lt;/strong&gt;&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;下面的命令使得有48%可能性从page heap中分配。同样，如果可用内存低于48%，则所有分配都会从标准堆中进行：&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;&lt;strong&gt;!dphflags 0x3000300F&lt;/strong&gt;&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参见&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;&lt;a&gt;&lt;strong&gt;!dphdump&lt;/strong&gt;&lt;/a&gt;, &lt;a&gt;&lt;strong&gt;!dphfind&lt;/strong&gt;&lt;/a&gt;, &lt;a&gt;&lt;strong&gt;!dphhogs&lt;/strong&gt;&lt;/a&gt;
	&lt;h1&gt;!dphhogs
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!dphhogs&lt;/strong&gt; 扩展用于显示debug page heap hogs。
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!dphhogs&lt;/strong&gt; &lt;em&gt;Address&lt;/em&gt; [&lt;strong&gt;count&lt;/strong&gt;] [&lt;strong&gt;reset&lt;/strong&gt;] &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;em&gt;Address&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定堆的基地址或者堆句柄。 
&lt;p&gt;&lt;strong&gt;count&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;列表按照count来排序(而不是按字节)。
&lt;p&gt;&lt;strong&gt;reset&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;所有的allocation counts重置为0。
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:151px"&gt;&lt;col style="width:123px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;这个命令只能用于运行在x86处理器上的checked版本Windows NT 4.0。
&lt;p style="margin-left:21pt"&gt;如果在Windows 2000(Service Pack 1或之后)、Windows XP或之后版本Windows中查看page heap，应该使用&lt;a&gt;&lt;strong&gt;!heap&lt;/strong&gt;&lt;/a&gt; 扩展命令。
&lt;h4&gt;参见
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;&lt;a&gt;&lt;strong&gt;!dphdump&lt;/strong&gt;&lt;/a&gt;, &lt;a&gt;&lt;strong&gt;!dphfind&lt;/strong&gt;&lt;/a&gt;, &lt;a&gt;&lt;strong&gt;!dphflags&lt;/strong&gt;&lt;/a&gt;
	&lt;h1&gt;!dreg
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!dreg&lt;/strong&gt; 扩展命令显示注册表信息。 
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!dreg&lt;/strong&gt; [&lt;strong&gt;-d&lt;/strong&gt;|&lt;strong&gt;-w&lt;/strong&gt;] &lt;em&gt;KeyPath&lt;/em&gt;[&lt;strong&gt;!&lt;/strong&gt;&lt;em&gt;Value&lt;/em&gt;] &lt;br&gt;&lt;strong&gt;!dreg&lt;/strong&gt; &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;strong&gt;-d&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;二进制数据显示为DWORD。 
&lt;p&gt;&lt;strong&gt;-w&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;二进制数据显示为WORD。 
&lt;p&gt;&lt;em&gt;KeyPath&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定注册表路径。可以使用下面这些缩写： 
&lt;p style="margin-left:21pt"&gt;&lt;strong&gt;hklm&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;HKEY_LOCAL_MACHINE 
&lt;p style="margin-left:21pt"&gt;&lt;strong&gt;hkcu&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;HKEY_CURRENT_USER 
&lt;p style="margin-left:21pt"&gt;&lt;strong&gt;hkcr&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;HKEY_CLASSES_ROOT 
&lt;p style="margin-left:21pt"&gt;&lt;strong&gt;hku&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;HKEY_USERS 
&lt;p style="margin-left:21pt"&gt;如果没有使用缩写，则假定使用HKEY_LOCAL_MACHINE。
&lt;p&gt;&lt;em&gt;Value&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定要显示的注册表值。星号(&lt;strong&gt;*&lt;/strong&gt;)可以代表任何值。如果省略&lt;em&gt;Value&lt;/em&gt;，则显示所有子键。 
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:151px"&gt;&lt;col style="width:123px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;&lt;strong&gt;!dreg&lt;/strong&gt; 扩展用于在用户模式调试时显示注册表。 
&lt;p style="margin-left:21pt"&gt;在远程调试时由于可以查看远程机器的注册表，所以非常有用。从内核调试器控制用户模式调试器时也很有用，因为目标机冻结的时候是不能运行标准的注册表编辑器的。(这时也可以使用&lt;strong&gt;.sleep&lt;/strong&gt; 命令。查看&lt;a&gt;从内核调试器控制用户模式调试器&lt;/a&gt;获得详细信息。)
&lt;p style="margin-left:21pt"&gt;由于信息是按照容易阅读的格式显示的，所以本地调试时也有用。
&lt;p style="margin-left:21pt"&gt;如果在内核模式调试时使用&lt;strong&gt;!dreg&lt;/strong&gt;结果显示的是主控机上面的，而不是目标机上的。要显示目标机上的原始注册表信息，可以使用&lt;a&gt;&lt;strong&gt;!reg&lt;/strong&gt;&lt;/a&gt;扩展命令来替代。.
&lt;p style="margin-left:21pt"&gt;这里有一些示例。下面这个显示指定的注册表键下面所有子键：
&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;&lt;strong&gt;!dreg hkcu\Software\Microsoft&lt;/strong&gt;&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;下面显示指定的注册表键下面所有值：&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;&lt;strong&gt;!dreg System\CurrentControlSet\Services\Tcpip!*&lt;/strong&gt;&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;这条命令显示指定的注册表键下面的Start键值：&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;&lt;strong&gt;!dreg System\CurrentControlSet\Services\Tcpip!Start&lt;/strong&gt;&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;不带参数使用&lt;strong&gt;!dreg&lt;/strong&gt; 会在调试器命令窗口中显示该命令的简单帮助。&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;h4&gt;附加信息
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;关于注册表的信息，查看Windows Driver Kit (WDK) 文档，以及Mark Russinovich 和David Solomon&lt;em&gt;
		&lt;/em&gt;编写的&lt;em&gt;Microsoft Windows Internals&lt;/em&gt;。
&lt;h1&gt;!dt
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!dt&lt;/strong&gt; 扩展命令显示某个CSR线程的信息。 
&lt;p&gt;该命令不能和&lt;a&gt;&lt;strong&gt;dt (Display Type)&lt;/strong&gt;&lt;/a&gt;命令混淆。
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!dt&lt;/strong&gt; [&lt;strong&gt;v&lt;/strong&gt;] &lt;em&gt;CSR-Thread&lt;/em&gt; &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;strong&gt;v&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;详细输出。 
&lt;p&gt;&lt;em&gt;CSR-Thread&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定CSR线程的16进制地址。 
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:151px"&gt;&lt;col style="width:123px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Ntsdexts.dll&lt;/em&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;该扩展命令显示CSR线程关联的线程、进程、client ID、标志和引用计数。如果使用了详细模式，输出中还包含list pointer、线程句柄和等待块(wait block)。
&lt;h4&gt;参见
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;&lt;a&gt;&lt;strong&gt;!dp (!ntsdexts.dp)&lt;/strong&gt;&lt;/a&gt;
	&lt;img src="http://c.services.spaces.live.com/CollectionWebService/c.gif?cid=-5341356082337814461&amp;page=RSS%3a+WinDbg+%e6%96%87%e6%a1%a3%e7%bf%bb%e8%af%91----90&amp;referrer=" width="1px" height="1px" border="0" alt=""&gt;&lt;img style="position:absolute" alt="" width="0px" height="0px" src="http://c.live.com/c.gif?NC=31263&amp;amp;NA=1149&amp;amp;PI=73329&amp;amp;RF=&amp;amp;DI=3919&amp;amp;PS=85545&amp;amp;TP=netroc682.spaces.live.com&amp;amp;GT1=netroc682"&gt;</description><comments>http://netroc682.spaces.live.com/Blog/cns!B5DFB0F15D61E843!311.entry#comment</comments><guid isPermaLink="true">http://netroc682.spaces.live.com/Blog/cns!B5DFB0F15D61E843!311.entry</guid><pubDate>Tue, 12 Aug 2008 07:05:58 GMT</pubDate><slash:comments>0</slash:comments><msn:type>blogentry</msn:type><live:type>blogentry</live:type><live:typelabel>Blog entry</live:typelabel><wfw:commentRss>http://netroc682.spaces.live.com/blog/cns!B5DFB0F15D61E843!311/comments/feed.rss</wfw:commentRss><wfw:comment>http://netroc682.spaces.live.com/Blog/cns!B5DFB0F15D61E843!311.entry#comment</wfw:comment><dcterms:modified>2008-08-12T07:05:58Z</dcterms:modified></item><item><title>WinDbg 文档翻译----89</title><link>http://netroc682.spaces.live.com/Blog/cns!B5DFB0F15D61E843!309.entry</link><description>&lt;p&gt;&lt;span style="font-family:宋体;font-size:10pt"&gt;cc682/NetRoc
&lt;/span&gt;&lt;p&gt;&lt;a href="http://netroc682.spaces.live.com/"&gt;&lt;span style="font-family:宋体;font-size:10pt"&gt;http://netroc682.spaces.live.com/&lt;/span&gt;&lt;/a&gt;
	&lt;h1&gt;!vm
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!vm&lt;/strong&gt;扩展命令显示目标系统中虚拟内存使用统计的摘要信息。
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p&gt;Windows NT 4.0的语法
&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!vm&lt;/strong&gt; &lt;br&gt;
		&lt;/span&gt;&lt;p&gt;Windows 2000和之后的语法&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!vm&lt;/strong&gt; [&lt;em&gt;Flags&lt;/em&gt;] &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;em&gt;Flags&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;&lt;em&gt;(Windows 2000和之后)&lt;/em&gt; 指定命令输出中要显示哪些信息。可以是下面这些位的任意的和。默认值是0，会显示系统范围的内存使用统计，以及每个进程的内存统计。 
&lt;p style="margin-left:21pt"&gt;Bit 0 (0x1) 
&lt;p style="margin-left:21pt"&gt;不显示进程相关的统计。 
&lt;p style="margin-left:21pt"&gt;Bit 1 (0x2) 
&lt;p style="margin-left:21pt"&gt;显示内存管理线程的调用堆栈。
&lt;p style="margin-left:21pt"&gt;Bit 2 (0x4) 
&lt;p style="margin-left:21pt"&gt;&lt;em&gt;(Windows XP和之后)&lt;/em&gt; 显示终端服务器(terminal server)的内存使用情况。 
&lt;p style="margin-left:21pt"&gt;Bit 3 (0x8) 
&lt;p style="margin-left:21pt"&gt;&lt;em&gt;(Windows XP和之后)&lt;/em&gt; 显示页面文件写日志(page file write log)。 
&lt;p style="margin-left:21pt"&gt;Bit 4 (0x10) 
&lt;p style="margin-left:21pt"&gt;&lt;em&gt;(Windows XP和之后)&lt;/em&gt; 显示工作集所有者线程的调用堆栈(working set owner thread stacks)。 
&lt;p style="margin-left:21pt"&gt;Bit 5 (0x20) 
&lt;p style="margin-left:21pt"&gt;&lt;em&gt;(Windows XP和之后)&lt;/em&gt; 显示内核的虚拟内存使用情况。 
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:160px"&gt;&lt;col style="width:95px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Kdextx86.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Kdextx86.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Kdexts.dll&lt;/em&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;下面是当&lt;em&gt;Flags&lt;/em&gt; 为1时的简短输出的示例：
&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;kd&amp;gt; &lt;strong&gt;!vm 1&lt;/strong&gt;&lt;br&gt;&lt;br&gt;*** Virtual Memory Usage ***&lt;br&gt;      Physical Memory:     16270   (   65080 Kb)&lt;br&gt;      Page File: \??\E:\pagefile.sys&lt;br&gt;         Current:     98304Kb Free Space:     61044Kb&lt;br&gt;         Minimum:     98304Kb Maximum:       196608Kb&lt;br&gt;      Available Pages:      5543   (   22172 Kb)&lt;br&gt;      ResAvail Pages:       6759   (   27036 Kb)&lt;br&gt;      Locked IO Pages:       112   (     448 Kb)&lt;br&gt;      Free System PTEs:    45089   (  180356 Kb)&lt;br&gt;      Free NP PTEs:         5145   (   20580 Kb)&lt;br&gt;      Free Special NP:       336   (    1344 Kb)&lt;br&gt;      Modified Pages:        714   (    2856 Kb)&lt;br&gt;      NonPagedPool Usage:    877   (    3508 Kb)&lt;br&gt;      NonPagedPool Max:     6252   (   25008 Kb)&lt;br&gt;      PagedPool 0 Usage:     729   (    2916 Kb)&lt;br&gt;      PagedPool 1 Usage:     432   (    1728 Kb)&lt;br&gt;      PagedPool 2 Usage:     436   (    1744 Kb)&lt;br&gt;      PagedPool Usage:      1597   (    6388 Kb)&lt;br&gt;      PagedPool Maximum:   13312   (   53248 Kb)&lt;br&gt;      Shared Commit:        1097   (    4388 Kb)&lt;br&gt;      Special Pool:          229   (     916 Kb)&lt;br&gt;      Shared Process:       1956   (    7824 Kb)&lt;br&gt;      PagedPool Commit:     1597   (    6388 Kb)&lt;br&gt;      Driver Commit:         828   (    3312 Kb)&lt;br&gt;      Committed pages:     21949   (   87796 Kb)&lt;br&gt;      Commit limit:        36256   (  145024 Kb)&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;所有的内存使用都是以页面数和KB为单位。输出中最有用的信息如下：
&lt;div style="margin-left:21pt"&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:110px"&gt;&lt;col style="width:452px"&gt;&lt;tbody valign=top&gt;&lt;tr style="background:#bfbfbf"&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p style="margin-left:1pt"&gt;&lt;strong&gt;参数&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p style="margin-left:1pt"&gt;&lt;strong&gt;含义&lt;/strong&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p style="margin-left:1pt"&gt;&lt;strong&gt;physical memory&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p style="margin-left:1pt"&gt;系统中总的物理内存。&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p style="margin-left:1pt"&gt;&lt;strong&gt;available pages&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p style="margin-left:1pt"&gt;系统中可用内存的页面数，包括虚拟和物理内存。 &lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p style="margin-left:1pt"&gt;&lt;strong&gt;nonpaged pool usage&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p style="margin-left:1pt"&gt;非分页池中分配的页面总数。非分页池是不会换出到页面文件中的内存，所以它必须一直占用物理内存。如果这个数字过大，通常表示系统中某个地方存在内存泄露。&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;p style="margin-left:21pt"&gt;
 &lt;h4&gt;附加信息
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;&lt;a&gt;&lt;strong&gt;!memusage&lt;/strong&gt;&lt;/a&gt; 扩展命令可以用来分析物理内存的使用。关于内存管理的更多信息，查看Mark Russinovich 和David Solomon&lt;em&gt;
		&lt;/em&gt;编写的&lt;em&gt;Microsoft Windows Internals&lt;/em&gt;。
&lt;h1&gt;!vpb
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!vpb&lt;/strong&gt; 扩展显示某个卷参数块(volume parameter block (VPB))。
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!vpb&lt;/strong&gt; &lt;em&gt;Address&lt;/em&gt; &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;em&gt;Address&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定VPB的16进制地址。 
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:160px"&gt;&lt;col style="width:95px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Kdextx86.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Kdexts.dll&lt;/em&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;下面是一个例子。首先用&lt;a&gt;&lt;strong&gt;!devnode&lt;/strong&gt;&lt;/a&gt; 扩展显示设备树：
&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;kd&amp;gt; &lt;strong&gt;!devnode 0 1&lt;/strong&gt;&lt;br&gt;Dumping IopRootDeviceNode (= 0x80e203b8)&lt;br&gt;DevNode 0x80e203b8 for PDO 0x80e204f8&lt;br&gt;  InstancePath is &amp;quot;HTREE\ROOT\0&amp;quot;&lt;br&gt;  State = DeviceNodeStarted (0x308)&lt;br&gt;  Previous State = DeviceNodeEnumerateCompletion (0x30d)&lt;br&gt;  DevNode 0x80e56dc8 for PDO 0x80e56f18&lt;br&gt;    InstancePath is &amp;quot;Root\dmio\0000&amp;quot;&lt;br&gt;    ServiceName is &amp;quot;dmio&amp;quot;&lt;br&gt;    State = DeviceNodeStarted (0x308)&lt;br&gt;    Previous State = DeviceNodeEnumerateCompletion (0x30d)&lt;br&gt;  DevNode 0x80e56ae8 for PDO 0x80e56c38&lt;br&gt;    InstancePath is &amp;quot;Root\ftdisk\0000&amp;quot;&lt;br&gt;    ServiceName is &amp;quot;ftdisk&amp;quot;&lt;br&gt;    State = DeviceNodeStarted (0x308)&lt;br&gt;    Previous State = DeviceNodeEnumerateCompletion (0x30d)&lt;br&gt;    &lt;strong&gt;DevNode 0x80e152a0 for PDO 0x80e15cb8&lt;/strong&gt;&lt;br&gt;      InstancePath is &amp;quot;STORAGE\Volume\1&amp;amp;30a96598&amp;amp;0&amp;amp;Signature5C34D70COffset7E00Length60170A00&amp;quot;&lt;br&gt;      ServiceName is &amp;quot;VolSnap&amp;quot;&lt;br&gt;      TargetDeviceNotify List - f 0xe1250938  b 0xe14b9198&lt;br&gt;      State = DeviceNodeStarted (0x308)&lt;br&gt;      Previous State = DeviceNodeEnumerateCompletion (0x30d)&lt;br&gt;    .....&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;列出的最后一个节点是一个volume。使用 &lt;a&gt;&lt;strong&gt;!devobj&lt;/strong&gt;&lt;/a&gt; 扩展查看它的物理设备对象(physical device object (PDO))：&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;kd&amp;gt; &lt;strong&gt;!devobj 80e15cb8&lt;/strong&gt;&lt;br&gt;Device object (80e15cb8) is for:&lt;br&gt; HarddiskVolume1 \Driver\Ftdisk DriverObject 80e4e248&lt;br&gt;Current Irp 00000000 RefCount 14 Type 00000007 Flags 00001050&lt;br&gt;Vpb &lt;strong&gt;80e15c30&lt;/strong&gt; DevExt 80e15d70 DevObjExt 80e15e40 Dope 80e15bd8 DevNode 80e152a0 &lt;br&gt;ExtensionFlags (0000000000)  &lt;br&gt;AttachedDevice (Upper) 80e14c60 \Driver\VolSnap&lt;br&gt;Device queue is not busy.&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;列出的内容中包括VPB 地址。使用&lt;strong&gt;!vpb&lt;/strong&gt; 扩展和这个地址：&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;kd&amp;gt; &lt;strong&gt;!vpb 80e15c30&lt;/strong&gt;&lt;br&gt;Vpb at 0x80e15c30&lt;br&gt;Flags: 0x1 mounted &lt;br&gt;DeviceObject: 0x80de5020&lt;br&gt;RealDevice:   0x80e15cb8&lt;br&gt;RefCount: 14&lt;br&gt;Volume Label:           MY-DISK-C&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;附加信息&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;关于VPB的信息，查看Windows Driver Kit (WDK) 文档以及Mark Russinovich 和David Solomon&lt;em&gt;
		&lt;/em&gt;编写的&lt;em&gt;Microsoft Windows Internals&lt;/em&gt;。
&lt;h1&gt;!vpdd
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!vpdd&lt;/strong&gt; 扩展显示指定进程的物理地址、虚拟地址和内存内容。
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!vpdd&lt;/strong&gt; &lt;em&gt;Process VirtualAddress&lt;/em&gt; &lt;br&gt;&lt;strong&gt;!vpdd&lt;/strong&gt; &lt;em&gt;PID VirtualAddress&lt;/em&gt; &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;em&gt;Process&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定要显示内存的进程的地址。 
&lt;p&gt;&lt;em&gt;PID&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定要显示内存的进程的PID(process ID)。 
&lt;p&gt;&lt;em&gt;VirtualAddress&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定要查看的页面的虚拟地址。 
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:160px"&gt;&lt;col style="width:95px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Kdextx86.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;下面是一个示例。假设要查看&lt;em&gt;cmd.exe&lt;/em&gt;进程保存在虚拟地址0x4AD00000处的内存内容。首先使用&lt;a&gt;&lt;strong&gt;!process&lt;/strong&gt;&lt;/a&gt; 来查看进程地址：
&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;kd&amp;gt; &lt;strong&gt;!process 0 0&lt;/strong&gt;&lt;br&gt;&lt;strong&gt;.......&lt;/strong&gt;&lt;br&gt;PROCESS 810e0020  SessionId: 0  Cid: 04e4    Peb: 7ffdf000  ParentCid: 014c&lt;br&gt;    DirBase: 0268a000  ObjectTable: 810db008  TableSize:  22.&lt;br&gt;    Image: CMD.EXE&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;&lt;strong&gt;!vpdd&lt;/strong&gt; 的首个参数可以使用进程地址(0x810E0020)或者PID(0x4E4)。第二个参数是要显示的虚拟地址：&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;kd&amp;gt; &lt;strong&gt;!vpdd  810e0020 4ad00000&lt;/strong&gt;&lt;br&gt;00fcf000 4ad00000  00905a4d 00000003 00000004 0000ffff&lt;br&gt;00fcf010 4ad00010  000000b8 00000000 00000040 00000000&lt;br&gt;00fcf020 4ad00020  00000000 00000000 00000000 00000000&lt;br&gt;00fcf030 4ad00030  00000000 00000000 00000000 000000d0&lt;br&gt;00fcf040 4ad00040  0eba1f0e cd09b400 4c01b821 685421cd&lt;br&gt;00fcf050 4ad00050  70207369 72676f72 63206d61 6f6e6e61&lt;br&gt;00fcf060 4ad00060  65622074 6e757220 206e6920 20534f44&lt;br&gt;00fcf070 4ad00070  65646f6d 0a0d0d2e 00000024 00000000&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;输出中，第一列是物理地址，第二列是虚拟地址。每行中剩下的内容是该位置保存的内容，以DWORD的形式。&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;h4&gt;附加信息
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;相关主题，查看&lt;a&gt;&lt;strong&gt;!vtop&lt;/strong&gt;&lt;/a&gt;、 &lt;a&gt;&lt;strong&gt;!ptov&lt;/strong&gt;&lt;/a&gt;、以及&lt;a&gt;将虚拟地址转换成物理地址&lt;/a&gt;。关于页表和页目录的信息，查看 Mark Russinovich 和David Solomon 编写的&lt;em&gt;Microsoft Windows Internals&lt;/em&gt;。
&lt;h1&gt;!vtop
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!vtop&lt;/strong&gt; 扩展命令将虚拟地址转换成对应的物理地址，并且显示其他的页表和页目录信息。
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p&gt;Windows 2000的语法
&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!vtop&lt;/strong&gt; &lt;em&gt;PFN VirtualAddress&lt;/em&gt; &lt;br&gt;
		&lt;/span&gt;&lt;p&gt;Windows XP和之后的语法&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!vtop&lt;/strong&gt; &lt;em&gt;PFN VirtualAddress&lt;/em&gt; &lt;br&gt;&lt;strong&gt;!vtop 0&lt;/strong&gt;&lt;em&gt; VirtualAddress&lt;/em&gt; &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;em&gt;DirBase&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定进程页目录的基址。每个进程都有自己的虚拟地址空间。使用&lt;a&gt;&lt;strong&gt;!process&lt;/strong&gt;&lt;/a&gt;扩展命令来查看进程的页目录基址。 
&lt;p&gt;&lt;em&gt;PFN&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定进程页目录基址的页面帧序号(PFN)。 
&lt;p&gt;&lt;strong&gt;0&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;&lt;em&gt;(Windows XP和之后)&lt;/em&gt;让&lt;strong&gt;!vtop&lt;/strong&gt; 使用当前的&lt;a&gt;进程上下文&lt;/a&gt;进行地址转换。
&lt;p&gt;&lt;em&gt;VirtualAddress&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定要转换的页面的虚拟地址。 
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:160px"&gt;&lt;col style="width:95px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Kdextx86.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Kdextx86.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Kdexts.dll&lt;/em&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;要使用这个命令，首先应该用&lt;a&gt;&lt;strong&gt;!process&lt;/strong&gt;&lt;/a&gt;扩展来查看进程的页目录基址。页目录基址的页面帧序号(PFN)可以通过将它的地址最后三个16进制0数字去掉来获得(换句话说，就是右移12位)。
&lt;p style="margin-left:21pt"&gt;下面是一个示例：
&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;kd&amp;gt; &lt;strong&gt;!process 0 0&lt;/strong&gt;&lt;br&gt;**** NT ACTIVE PROCESS DUMP ****&lt;br&gt;....&lt;br&gt;PROCESS ff779190  SessionId: 0  Cid: 04fc    Peb: 7ffdf000  ParentCid: 0394&lt;br&gt;    &lt;strong&gt;DirBase: 098fd000&lt;/strong&gt;  ObjectTable: e1646b30  TableSize:   8.&lt;br&gt;    Image: MyApp.exe&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;如果页目录基地址为0x098FD000，那么它的PFN 为0x098FD。&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;kd&amp;gt;&lt;strong&gt; !vtop 98fd 12f980&lt;/strong&gt;&lt;br&gt;Pdi 0 Pti 12f&lt;br&gt;0012f980 09de9000 pfn(09de9)&lt;br&gt;&lt;br&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;注意最后三个0是可选的(貌似原文有错漏Notice how the trailing three zeros are optional.)。&lt;strong&gt;!vtop&lt;/strong&gt;扩展命令会显示页目录索引(page directory index (PDI))、页表索引(page table index (PTI))、输入的虚拟地址、物理页面开始位置的物理地址、以及页表项(PTE)的页面帧序号(PFN)。&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;如果要将虚拟地址0x0012F980 转换成物理地址，只需要简单的将最后三个16进制数字 (0x980)加到页面开始处的物理地址(0x09DE9000)上。得到的物理地址为0x09DE9980。
&lt;p style="margin-left:21pt"&gt;如果忘记去掉那三个0，并且将完整的页目录基址传递给了&lt;strong&gt;!vtop&lt;/strong&gt;，而不是 使用PFN，那么结果通常都会是正确的。这是由于&lt;strong&gt;!vtop&lt;/strong&gt; 接收到一个太大的PFN数字时，会将它右移16位后再使用：
&lt;p style="margin-left:21pt"&gt;&lt;span style="color:#660000;font-family:Courier New"&gt;kd&amp;gt;&lt;strong&gt; !vtop 98fd 12f980&lt;/strong&gt;&lt;br&gt;Pdi 0 Pti 12f&lt;br&gt;0012f980 09de9000 pfn(09de9)&lt;br&gt;&lt;br&gt;kd&amp;gt; &lt;strong&gt;!vtop 98fd000 12f980&lt;/strong&gt;&lt;br&gt;Pdi 0 Pti 12f&lt;br&gt;0012f980 09de9000 pfn(09de9)&lt;br&gt;
		&lt;/span&gt;&lt;p style="margin-left:21pt"&gt;但是，最好还是使用PFN，因为有些页目录基址在这种情况下不会被转换。&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;h4&gt;附加信息
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;关于获得这些结果的其他方法，查看&lt;a&gt;将虚拟地址转换成物理地址&lt;/a&gt;。还可以查看&lt;a&gt;&lt;strong&gt;!ptov&lt;/strong&gt;&lt;/a&gt; 和&lt;a&gt;&lt;strong&gt;!vpdd&lt;/strong&gt;&lt;/a&gt;。关于页表和页目录的信息，查看Mark Russinovich 和David Solomon 编写的&lt;em&gt;Microsoft Windows Internals&lt;/em&gt;。
&lt;h1&gt;!walklist
&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;!walklist &lt;/strong&gt;扩展命令在当前会话的会话链表中搜索某个地址。
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!walklist &lt;/strong&gt;[&lt;strong&gt;-a&lt;/strong&gt;] [&lt;strong&gt;-o &lt;/strong&gt;&lt;em&gt;Offset&lt;/em&gt;] &lt;em&gt;StartAddress SearchAddress&lt;/em&gt;&lt;br&gt;&lt;strong&gt;!walklist&lt;/strong&gt; -&lt;strong&gt;?&lt;/strong&gt; &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;strong&gt;-a&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;搜索所有会话列表。
&lt;p&gt;&lt;strong&gt;-o &lt;/strong&gt;&lt;em&gt;Offset&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定链表中next字段的偏移。 
&lt;p&gt;&lt;em&gt;StartAddress&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定会话链表的起始地址。 
&lt;p&gt;&lt;em&gt;SearchAddress&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定要在链表中搜索的地址。 
&lt;p&gt;&lt;strong&gt;-?&lt;/strong&gt;
	&lt;p style="margin-left:21pt"&gt;在调试器命令窗口中显示该扩展命令的帮助。 
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:160px"&gt;&lt;col style="width:95px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Kdexts.dll&lt;/em&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;附加信息
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;关于会话的信息，查看&lt;a&gt;改变上下文&lt;/a&gt;。关于内存池和pool tag的信息，查看Windows Driver Kit (WDK) 文档，以及Mark Russinovich 和David Solomon&lt;em&gt;
		&lt;/em&gt;编写的&lt;em&gt;Microsoft Windows Internals&lt;/em&gt;。
&lt;h1&gt;!wdmaud
&lt;/h1&gt;&lt;p&gt;显示各种WDM Audio (WDMAud)结构。 
&lt;h4&gt;语法
&lt;/h4&gt;&lt;p style="background:#dddddd"&gt;&lt;span style="font-family:Courier New"&gt;&lt;strong&gt;!wdmaud&lt;/strong&gt; &lt;em&gt;Address&lt;/em&gt; &lt;em&gt;Flags&lt;/em&gt; &lt;br&gt;
		&lt;/span&gt;&lt;h4&gt;参数&lt;span style="font-family:宋体"&gt;
		&lt;/span&gt;&lt;/h4&gt;&lt;p&gt;&lt;em&gt;Address&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定要显示的结构地址。 
&lt;p&gt;&lt;em&gt;Flags&lt;/em&gt;
	&lt;p style="margin-left:21pt"&gt;指定要显示的信息。必须只包含bits 0x1、0x2、0x4和0x8中的&lt;em&gt;一个&lt;/em&gt;。0x100 可以和它们中任何一个共同使用。 
&lt;p style="margin-left:21pt"&gt;Bit 0 (0x1) 
&lt;p style="margin-left:21pt"&gt;显示已经发送给&lt;em&gt;wdmaud.sys&lt;/em&gt;过的IOCTL的列表。使用时，&lt;em&gt;Address&lt;/em&gt; 需要指定&lt;strong&gt;WdmaIoctlHistoryListHead&lt;/strong&gt;的地址。如果设置了0x100这个位，还会显示每个IOCTL发送的&lt;strong&gt;pContext&lt;/strong&gt; 。
&lt;p style="margin-left:21pt"&gt;Bit 1 (0x2) 
&lt;p style="margin-left:21pt"&gt;显示标记为pending的IRP列表。&lt;em&gt;Address&lt;/em&gt;指定&lt;strong&gt;WdmaPendingIrpListHead&lt;/strong&gt;的地址。如果设置了0x100这个位，还会显示每个IRP分配时的context。 
&lt;p style="margin-left:21pt"&gt;Bit 2 (0x4) 
&lt;p style="margin-left:21pt"&gt;显示WDMAud 分配的MDL列表。&lt;em&gt;Address&lt;/em&gt; 指定&lt;strong&gt;WdmaAllocatedMdlListHead&lt;/strong&gt;的地址。如果设置了0x100位，还显示每个MDL分配时的context。 
&lt;p style="margin-left:21pt"&gt;Bit 3 (0x8) 
&lt;p style="margin-left:21pt"&gt;显示附加到&lt;em&gt;wdmaud.sys&lt;/em&gt; 上的所有活动context的列表。&lt;em&gt;Address&lt;/em&gt;需要指定 &lt;strong&gt;WdmaContextListHead&lt;/strong&gt;的地址。如果设置了0x100位，还会显示每个context结构中的数据成员。 
&lt;p style="margin-left:21pt"&gt;Bit 8 (0x100) 
&lt;p style="margin-left:21pt"&gt;显示详细信息。 
&lt;h4&gt;DLL
&lt;/h4&gt;&lt;div&gt;&lt;table style="border-collapse:collapse" border=0&gt;&lt;colgroup&gt;&lt;col style="width:160px"&gt;&lt;col style="width:95px"&gt;&lt;tbody valign=top&gt;&lt;tr&gt;&lt;td style="border-top:solid black 0.5pt;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows NT 4.0&lt;/strong&gt;&lt;td style="border-top:solid black 0.5pt;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows 2000&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;em&gt;Kdextx86.dll&lt;/em&gt;&lt;tr&gt;&lt;td style="border-top:none;border-left:solid black 0.5pt;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;&lt;strong&gt;Windows XP和之后&lt;/strong&gt;&lt;td style="border-top:none;border-left:none;border-bottom:solid black 0.5pt;border-right:solid black 0.5pt"&gt;&lt;p&gt;不可用&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;&lt;h4&gt;注释
&lt;/h4&gt;&lt;p style="margin-left:21pt"&gt;附加到&lt;em&gt;wdmaud.sys&lt;/em&gt; 的context(&lt;strong&gt;pContext&lt;/strong&gt;)包含了每个device的大多数状态数据。每次&lt;em&gt;wdmaud.drv&lt;/em&gt; 被加载进一个新的进程时，会通报&lt;em&gt;wdmaud.sys&lt;/em&gt;