说明我的问题的最好方法是用这个例子(如果我使用strstr
CRT 函数,这不起作用):
const wchar_t* s1 = L"Hauptstraße ist die längste";
const wchar_t* s2 = L"Hauptstrasse";
bool b_s1_starts_with_s2 = !!wcsstr(s1, s2);
_ASSERT(b_s1_starts_with_s2); //Should be true
到目前为止,唯一似乎可以识别语言字符串等效性的 WinAPI 在与LINGUISTIC_IGNORECASE
标志一起使用时CompareStringEx
,但用于此目的有点棘手和效率低下,因为我将不得不反复调用它s2
直到我到达它的末尾。
所以我想知道是否有更好的方法来做到这一点(在 Windows 下)?
编辑:这是我的意思:
bool b_s1_starts_with_s2 = false;
int ln1 = (int)wcslen(s1);
int ln2 = (int)wcslen(s2);
for(int p = 1; p <= ln1; p++)
{
if(::CompareString(LOCALE_USER_DEFAULT, LINGUISTIC_IGNORECASE,
s1, p,
s2, ln2) == CSTR_EQUAL)
{
//Match
b_s1_starts_with_s2 = true;
break;
}
}
您可以使用FindNLSString
,检查返回值是否为零。
显然,它与ß
ss
相匹配
const wchar_t *s1 = L"Hauptstraße ist die längste";
const wchar_t *s2 = L"Hauptstrasse";
INT found = 0;
int start = FindNLSString(0, LINGUISTIC_IGNORECASE, s1, -1, s2, -1, &found);
wprintf(L"start = %dn", start);
s1 = L"δεθ Testing Greek";
s2 = L"ΔΕΘ";
start = FindNLSString(0, LINGUISTIC_IGNORECASE, s1, -1, s2, -1, &found);
wprintf(L"start = %dn", start);
我没有尝试过,但我认为您可能可以使用LCMapStringEx
将所有字符串转换为适合区域设置的小写,然后与wcsncmp
进行正常的字符串前缀匹配。
(如注释中所述,在示例中使用wcsstr
是没有意义的,因为wcsstr
确定一个字符串是否包含另一个字符串。 若要确定一个字符串是否以另一个字符串开头,将wcsncmp
与前缀字符串的长度一起使用会更有效。