我正在尝试将此输入\x01\xc3\xa4\xc3\xb6\xc3\xbc\xff转义为该\\x01\\xc3\\xa4\\xc3\\xb6\\xc3\\xbc\\xff以使用printf("%s",input)将其打印出来。通常,我必须转义各种输入,并使用\ t,\ n等转义序列。

为此,我编写了以下函数:

void kvstr_escape_string(char* dest, const KV_Buffer* src)
{
char c;
int i = 0;
const char* data = src->data; // src->data is a char*

while (src != NULL && i < src->length && (c = *(data++))) {
    switch(c) {
        case '\a':
                *(dest++) = '\\';
                *(dest++) = 'a';
                break;
        case '\b':
                *(dest++) = '\\';
                *(dest++) = 'b';
                break;
        case '\t':
                *(dest++) = '\\';
                *(dest++) = 't';
                break;
        case '\n':
                *(dest++) = '\\';
                *(dest++) = 'n';
                break;
        case '\v':
                *(dest++) = '\\';
                *(dest++) = 'v';
                break;
        case '\f':
                *(dest++) = '\\';
                *(dest++) = 'f';
                break;
        case '\r':
                *(dest++) = '\\';
                *(dest++) = 'r';
                break;
        case '\\':
                *(dest++) = '\\';
                break;
        case '\"':
                *(dest++) = '\\';
                *(dest++) = '\"';
                break;
        case '\x01':
                *(dest++) = '\\';
                *(dest++) = 'x';
                *(dest++) = '0';
                *(dest++) = '1';
                break;
      // Here i need something to handle \xHH
        default:
                *(dest++) = c;
       }
       i++;
    }

    *(dest++) = '\0';
}


我的问题是在case '\x01':的情况下,如何处理函数中显示的所有\ xHH输入?我应该使用正则表达式吗?

[更新]请看Karel的回答。如果您想知道默认块的外观,下面是一个示例:

default:
        if (c < 32 || c > 126){
            *(dest++) = '\\';
            *(dest++) = 'x';
            sprintf(d, "%.2x", c);
            *(dest++) = d[0];
            *(dest++) = d[1];
        }else{
            *(dest++) = c;
        }

最佳答案

您的密码

case '\x01':
    *(dest++) = '\\';
    *(dest++) = 'x';
    *(dest++) = '0';
    *(dest++) = '1';
    break;


基本上只是为了将文字字节与值1匹配。您也可以将其写为

case 1:
    ...


我会将这个块移到default情况下,并匹配c是否小于等于31(32是空格)。另外,您可能希望转义ASCII值大于波浪号126的字符。从我的头顶上:

default:
    if (c < 32 || c > 126)
        // add "\\x" followed by two hex digits of the value of c
    else
        // simply add the value of c


至于将值转换为两个十六进制字符的方法,我将使用较小的转换缓冲区和sprintf()。希望这可以帮助!

10-05 23:17