解决QT的QString arg()模糊性问题

Ole*_*nko 12 qstring qt ambiguity

QString::arg()当字符串包含位置标记之后的数字时,会出现问题.从QString::arg()功能描述中不清楚在这种替换的情况下会发生什么:

QString("String for replacement %1234").arg("blah");
Run Code Online (Sandbox Code Playgroud)

这会导致"String for replacement blah234""String for replacement blah34"

我查看了QT的源代码来回答这个问题.看起来寻找位置标记的算法似乎是"贪婪的",并且在上面的例子中它将采用两个数字.

以下是QString::arg()(QT 4.8.4)中使用的QT函数的来源:

static ArgEscapeData findArgEscapes(const QString &s)
{
const QChar *uc_begin = s.unicode();
const QChar *uc_end = uc_begin + s.length();

ArgEscapeData d;

d.min_escape = INT_MAX;
d.occurrences = 0;
d.escape_len = 0;
d.locale_occurrences = 0;

const QChar *c = uc_begin;
while (c != uc_end) {
    while (c != uc_end && c->unicode() != '%')
        ++c;

    if (c == uc_end)
        break;
    const QChar *escape_start = c;
    if (++c == uc_end)
        break;

    bool locale_arg = false;
    if (c->unicode() == 'L') {
        locale_arg = true;
        if (++c == uc_end)
            break;
    }

    if (c->digitValue() == -1)
        continue;

    int escape = c->digitValue();
    ++c;

    if (c != uc_end && c->digitValue() != -1) {
        escape = (10 * escape) + c->digitValue();
        ++c;
    }

    if (escape > d.min_escape)
        continue;

    if (escape < d.min_escape) {
        d.min_escape = escape;
        d.occurrences = 0;
        d.escape_len = 0;
        d.locale_occurrences = 0;
    }

    ++d.occurrences;
    if (locale_arg)
        ++d.locale_occurrences;
    d.escape_len += c - escape_start;
}
return d;
}
Run Code Online (Sandbox Code Playgroud)

有没有比使用2位数字位置标记更好的解决这种模糊性的方法?

小智 4

由于您只能使用%1to%99作为标记,并且可以跳过标记编号,因此您可以编写:

QString("String for replacement %10234").arg("blah");
Run Code Online (Sandbox Code Playgroud)

输出字符串进行替换blah234