//: Playground - noun: a place where people can play
import UIKit
// # 字符串字面量
// 多行字符串字面量,也是String类型。String理论上也能做到多行,只是这样更方便了。
let quotation = """
The White Rabbit put on his spectacles. "Where shall I begin,
please your Majesty?" he asked.
"Begin at the beginning," the King said gravely, "and go on
till you come to the end; then stop."
"""
// 在多行字符串中使用三引号,用反斜杠转译至少一个双引号,借此避免真三引号的出现。另注意缩进以结尾三引号为准。
let threeDoubleQuotes = """
Escaping the first quote \"""
Escaping all three quotes \"\"\"
"""
print(threeDoubleQuotes)
// # 初始化一个空字符串
// trick: 检查是否为空
var emptyString = ""
if emptyString.isEmpty {
print("Nothing to see here")
}
// # 字符串可变性
// # 字符串是值类型
// trick: 字符串是值类型,在c中改变a、b对a、b本身无影响
var a = "wanna"
var b = "gonna"
var c = [a, b]
// # 操作字符
// for-in loop
for character in "Dog!🐶" {
print(character)
}
// 单独创建字符类型,但用的仍是字符串字面量
let exclamationMark: Character = "!"
// String值可以通过传入 Character值的字符串作为实际参数到它的初始化器来构造,这是因为String有这样的init
let catCharacters: [Character] = ["C", "a", "t", "!", "🐱"]
let catString = String(catCharacters)
// # 连接字符串和字符
var welcome = ""
welcome += "Bonjour"
welcome.append(exclamationMark)
// # 字符串插值
// # Unicode
// Unicode 是一种在不同书写系统中编码、表示和处理文本的国际标准。不是所有的Unicode标量码都对应着字符
// 字符串字面量中的转译特殊字符
"\0"// 空字符
"\\"// 反斜杠
"\t"// 水平制表符
"\n"// 换行符,n是指newline
"\r"// 回车符,r是指return,以上两者在mac下没有什么区别???
"\""// 双引号
"\'"// 单引号
print("hao\rde")
"\u{1F443}" // 用Unicode标量码
// 扩展字形集群
let precomposed: Character = "\u{D55C}" // 한
let decomposed: Character = "\u{1112}\u{1161}\u{11AB}" // ᄒ, ᅡ, ᆫ
let enclosedEAcute: Character = "\u{E9}\u{20DD}" // 封闭标记
// 区域指示符号的 Unicode 标量可以成对组合来成为单一的 Character值
let regionalIndicatorForUS: Character = "\u{1F1FA}\u{1F1F8}"
// # 字符统计
// 注意.count属性要遍历所有Unicode标量码才能断定字符个数,而不是简单的Unicode码个数
var word = "cafe"
word.count
word += "\u{301}" // combined
word.count
// # 访问和修改字符串
// String不是[Character],下标运算不能用整数,只能用index。原因就在于扩展字形集群导致每个字符所占大小可以变化,用整数就会出现一个字符的某个部分这种情况
// endIndex属性是 String中最后一个字符后的位置,并非最后一个字符位置.如果 String为空,则 startIndex与 endIndex相等。
var greeting = "Bonjour!"
greeting[greeting.startIndex]
greeting[greeting.index(after: greeting.startIndex)]
greeting[greeting.index(before: greeting.endIndex)]
// 用offsetBy来向右偏移
greeting[greeting.index(greeting.startIndex, offsetBy: 1)]
// .indices获得了所有有效的index(无endIndex)
for index in greeting.indices {
print("\(greeting[index])", terminator: "")
}
// 可以在任何遵循了 Indexable 协议的类型中使用 startIndex 和 endIndex 属性以及 index(before:) , index(after:) 和 index(_:offsetBy:) 方法。这包括这里使用的 String ,还有集合类型比如 Array , Dictionary 和 Set 。
var test = [1, 2, 3]
test[test.startIndex]
test[0]
// 删除,remove(at:)返回了一个Character
greeting.remove(at: greeting.index(before: greeting.endIndex))
greeting.removeSubrange(greeting.startIndex..<greeting.endIndex)
// 插入
greeting.insert(contentsOf: ", wee", at: greeting.endIndex)
greeting.insert("!", at: greeting.endIndex)
// 可以在任何遵循了 RangeReplaceableIndexable 协议的类型中使用 insert(_:at:) , insert(contentsOf:at:) , remove(at:) 方法。这包括了这里使用的 String ,同样还有集合类型比如 Array , Dictionary 和 Set.
// # 字符串比较
// 只要String或Character的扩展字形集群拥有相同的语言意义和外形,我们就说它规范化相等,就算它们实际上是由不同的 Unicode 标量组合而成。
// 调用hasPrefix(_:),hasSuffix(_:)返回布尔值来判断字符串是否拥有特定前后缀
// # 字符串的Unicode表示法
// 字符串的Unicode标量会被编码为一定格式
// UTF-8表示法, UTF-16表示法, Unicode标量表示法
网友评论