栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

Swift中的字符串和字符比较不区分语言环境是什么意思?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Swift中的字符串和字符比较不区分语言环境是什么意思?

(现在已为Swift 3更新所有代码示例。)

夫特串与比较<确实基于逐一比较所谓“Unipre范式
d”(其可以与被计算decomposedStringWithCanonicalMapping)

例如,分解

"ä" = U+00E4 = LATIN SMALL LETTER A WITH DIAERESIS

是两个Unipre代码点的序列

U+0061,U+0308 = LATIN SMALL LETTER A + COMBINING DIAERESIS

出于演示目的,我编写了一个小的String扩展名,该扩展名将String 的内容转储为Unipre代码点的数组:

extension String {    var unipredata: String {        return self.unipreScalars.map { String(format: "%04X", $0.value) }.joined(separator: ",")    }}

现在,让我们取一些字符串,用<以下命令对其进行排序:

let someStrings = ["ǟψ", "äψ", "ǟx", "äx"].sorted()print(someStrings)// ["a", "ã", "ă", "ä", "ǟ", "b"]

并将每个字符串(原始和分解
形式)的Unipre代码点转储到排序数组中:

for str in someStrings {    print("(str)  (str.unipreData)  (str.decomposedStringWithCanonicalMapping.unipreData)")}

The output

äx  00E4,0078  0061,0308,0078ǟx  01DF,0078  0061,0308,0304,0078ǟψ  01DF,03C8  0061,0308,0304,03C8äψ  00E4,03C8  0061,0308,03C8

很好地显示了该比较是通过分解形式的Unipre代码点的字典顺序进行的。

如以下
示例所示,对于多个字符的字符串也是如此。用

let someStrings = ["ǟψ", "äψ", "ǟx", "äx"].sorted()

以上循环的输出是

äx  00E4,0078  0061,0308,0078ǟx  01DF,0078  0061,0308,0304,0078ǟψ  01DF,03C8  0061,0308,0304,03C8äψ  00E4,03C8  0061,0308,03C8

意思就是

"äx" < "ǟx", but "äψ" > "ǟψ"

(这至少对我来说是出乎意料的)。

最后,让我们将其与语言环境敏感的顺序进行比较,例如
瑞典语:

let locale = Locale(identifier: "sv") // svenskavar someStrings = ["ǟ", "ä", "ã", "a", "ă", "b"]someStrings.sort {    $0.compare($1, locale: locale) == .orderedAscending}print(someStrings)// ["a", "ă", "ã", "b", "ä", "ǟ"]

As you see, the result is different from the Swift

<
sorting.



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/387490.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号