C语言中 printf 无符号字符数组

3

我有一个无符号字符数组unsigned char* name = malloc(nameLength); - 我如何使用printf打印它?%s似乎不能正常工作,%u也不行(会看到随机图标)。

这是我创建要打印的数据的方法:

__int32 nameLength;
ReadProcessMemory(hProcess, (LPCVOID)(classNamePtr + 0x0004), &nameLength, sizeof(__int32), 0); //Reads nameLength to be 13 in this case
unsigned char* name = malloc(nameLength+5); //Add 5 for good measure, it is null terminated
ReadProcessMemory(hProcess, (LPCVOID)(nameStrPtr), name, nameLength, 0);
name[nameLength] = 0; //null terminate

printf("%s", name); //Outputs single character strange characters, like an up icon

你没有给我们足够的信息。请阅读http://sscce.org/。 - Keith Thompson
我已经添加了更多的信息@KeithThompson - Christian Stewart
在代码中,我这样做 - name[nameLength] = 0 - Christian Stewart
@abelenky 我知道那个位置里面是什么(它是一个指针的目标)- 如果你正在扫描内存,你肯定可以找到莎士比亚 :) - Christian Stewart
通过刚刚添加的信息,您的程序按预期工作。您读取的内存区域具有不可打印的值。您最好以十六进制(或十进制)的形式打印它们,或者接受%s所呈现的值。 - gnometorule
显示剩余6条评论
1个回答

1
当检测到不可打印字符时,输出转义序列或十六进制值。
#include <ctype.h>
#include <string.h>
#include <stdio.h>

int printf_ByteArray(const unsigned char *data, size_t len) {
  size_t i;
  int result = 0;
  for (i = 0; i < len; i++) {
    int y;
    int ch = data[i];
    static const char escapec[] = "\a\b\t\n\v\f\n\'\"\?\\";
    char *p = strchr(escapec, ch);
    if (p && ch) {
      static const char escapev[] = "abtnvfn\'\"\?\\";
      y = printf("\\%c", escapev[p - escapec]);
    } else if (isprint(ch)) {
      y = printf("%c", ch);
    } else {
      // If at end of array, assume _next_ potential character is a '0'.
      int nch = i >= (len - 1) ? '0' : data[i + 1];
      if (ch < 8 && (nch < '0' || nch > '7')) {
        y = printf("\\%o", ch);
      } else if (!isxdigit(nch)) {
        y = printf("\\x%X", ch);
      } else {
        y = printf("\\o%03o", ch);
      }
    }
    if (y == EOF)
      return EOF;
    result += y;
  }
  return result;
}

如果data包含每个字节,示例如下:

\0...\6\a\b\t\n\v\f\xD\xE\xF\x10...\x1F !\"#$%&\'()*+,-./0123456789:;<=>\?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~\x7F...\xFE\o377

转义序列的选择将随着代码目标而变化。上面的集合试图符合C解析器接受的内容。
注意:对于最后一个else,始终输出3位八进制序列具有扫描优势,但人们更习惯于十六进制而不是八进制。
根据以下字符有条件地打印十六进制进行调整。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接