"\"ʿAbdul-Baha'\"^^mso:text@de".StartsWith("\"") // is false
"\"Abdul-Baha'\"^^mso:text@de".StartsWith("\"") // is true
(int)'ʿ' // is 703`
有没有人可以告诉我为什么?
"\"ʿAbdul-Baha'\"^^mso:text@de".StartsWith("\"") // is false
"\"Abdul-Baha'\"^^mso:text@de".StartsWith("\"") // is true
(int)'ʿ' // is 703`
有没有人可以告诉我为什么?
您需要使用函数的第二个参数BeginsWith
;StringComparison.Ordinal
(或StringComparison.OrdinalIgnoreCase
)。这指示函数按字符值进行比较,并且在排序时不考虑文化信息。此引用来自下面的 MSDN 链接:
“使用单词排序规则的操作执行文化敏感比较,其中某些非字母数字 Unicode 字符可能具有分配给它们的特殊权重。使用单词排序规则和特定文化的约定,连字符 (“-”) 可能具有非常分配给它的权重很小,以便“合作”和“合作”在排序列表中彼此相邻出现。”
这似乎会影响 BeginsWith 的执行方式,具体取决于语言环境/文化(请参阅 OP 帖子的评论)——它适用于某些人,但不适用于其他人。
在下面的示例(单元测试)中,我展示了如果将字符串转换为 char 数组并查看第一个字符,它实际上是相同的。调用 BeginsWith 函数时,您需要添加 Ordinal 比较以获得相同的结果。
作为参考,我的语言环境是瑞典语。
欲了解更多信息:MSDN:StringComparison Enumeration
[Test]
public void BeginsWith_test()
{
const string string1 = "\"ʿAbdul-Baha'\"^^mso:text@de";
const string string2 = "\"Abdul-Baha'\"^^mso:text@de";
var chars1 = string1.ToCharArray();
var chars2 = string2.ToCharArray();
Assert.That(chars1[0], Is.EqualTo('"'));
Assert.That(chars2[0], Is.EqualTo('"'));
Assert.That(string1.StartsWith("\"", StringComparison.InvariantCulture), Is.False);
Assert.That(string1.StartsWith("\"", StringComparison.CurrentCulture), Is.False);
Assert.That(string1.StartsWith("\"", StringComparison.Ordinal), Is.True); // Works
Assert.That(string2.StartsWith("\""), Is.True);
}