Chinaunix首页 | 论坛 | 博客
  • 博客访问: 175248
  • 博文数量: 18
  • 博客积分: 476
  • 博客等级: 下士
  • 技术积分: 187
  • 用 户 组: 普通用户
  • 注册时间: 2010-07-27 20:42
个人简介

~

文章分类
文章存档

2014年(2)

2011年(10)

2010年(6)

分类: WINDOWS

2011-06-27 16:40:08

使用DbgPrint 打印字符串和其他


1) 直接打印字符串。

  DbgPrint(“Hello World!”);


2) 
空结尾的字符串,你可以用普通得C 语法表示字符串常量 
    char variable_string[] = “Hello World”; 
   DbgPrint(“%s”,variable_string);

 

3) 空结尾的宽字符串(WCHAR 类型 
WCHAR    string_w[] = L“Hello World!”; 
DbgPrint(“%ws”,string_w);

或者

DbgPrint(“%S”,string_w);

 

 

4)Unicode 串,由UNICODE_STRING 结构描述, 包含16 位字符。

typedef   struct _UNICODE_STRING{ 
       USHORT Length; 
       USHORT MaximumLength; 
      PWSTR   Buffer; 
}UNICODE_STRING , *PUNICODE_STRING;

 

UNICODE_STRING    string_unicode;

RtlInitUnicodeString(&string_unicode, L”Hello World!”);

DbgPrint(“%wZ\n”,&string_unicode);     

 

5) ANSI 串,由ANSI_STRING 结构描述,包含8 位字符。

typedef struct _STRING{ 
     USHORT Length; 
     USHORT MaximumLength; 
     PCHAR   Buffer; 
}STRING, *PANSI_STRING;

STRING bar; 
或者: ANSI_STRING bar; 
RtlInitAnsiString(&bar,”Hello World!”); 
DbgPrint(“%Z\n”,&bar);

 

DebugPrint 格式说明符

 

   根据DDK 上说明,Unicode 格式(%C, %S, %lc, %ls, %wc, %ws, and %wZ) 只能在 IRQL = PASSIVE_LEVEL 时才能使用.

 

参考文献:

1.      内核打印字符串

2.      DDK


以上转载自:
http://blog.csdn.net/misterliwei/archive/2008/12/19/3559793.aspx



DDK中的原话:DbgPrint and DbgPrintEx can be called at IRQL<=DIRQL. However, Unicode format codes (%wc and %ws) can be used only at IRQL PASSIVE_LEVEL. Also, because the debugger uses interprocess interrupts (IPIs) to communicate with other processors, calling DbgPrint at IRQL>DIRQL can cause deadlocks.
阅读(6872) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~