Swift入门(二)——字符与字符串

Swift字符

定义

Swift中的字符,与OC有些不同,每一个字符代表了一个可拓展的字母集,可拓展的字母集由若干个(大于等于一个)Unicode标量值表示,这些标量构成了一个可拓展的字母集,也就是一个人类可读的字符。

Unicode标量

一个Unicode标量占据21个比特位,一般格式为“U+xxxx”,这个解释有点抽象,其实我们通常理解的一个字母,也可以用一个Unicode标量来表示,比如字母’a’可以表示为”U+0061”。

刚刚说到,一个字符由若干个Unicode标量表示,比如以下这个例子:

let combine1 = "\u{1112}"
let combine2 = "\u{1112}\u{1161}"
let combine3 = "\u{1112}\u{1161}\u{11AB}"

println("combine1 = \(combine1)")
println("combine2 = \(combine2)")
println("combine3 = \(combine3)")

输出结果是

combine1 = ᄒ
combine2 = 하
combine3 = 한

可见,对于一个字符,并不一定是由一个Unicode标量构成的。比如“한”。

字符类型推导

刚刚的例子中,我们定义了三个常量,combine0,,combine1,combine2,他们被推导为什么类型呢?答案是String类型而不是Character类型,个人猜测是Swfit的宽类型优先导致的。这里通过简单的代码验证一下:

var combine0 = "\u{1112}"
var combine1:Character = "\u{1112}"

combine0 += "abc" //正确
combine1 += "abc" //编译错误:无法将String类型与Character类型变量拼接

字符拼接

在初始化字符类型常量或变量时,Swift会自动把能够拼接的Unicode标量拼接成一个人类可读字符,如果不能拼接,将生成一个由多个字符所组成的字符串。把这个值赋给一个已经标注为Character类型的变量会导致编译错误。

var string = "\u{1112}\u{10FFFF}" //正确,string变量被推导为String类型
var c:Character = "\u{1112}\u{10FFFF}" //错误,无法赋值给Character类型变量

Swift字符串

定义

Swift中的字符串由若干个字符构成。

字符串初始化

一共有两种方式可以进行字符串初始化,代码如下:

var emptyString1 = ""
var emptyString2 = String()

这样就创建了一个空字符串,可以用字符串的isEmpty属性来检验:

if emptyString1.isEmpty{
    println("emptyString1 is empty")
}
if emptyString2.isEmpty{
    println("emptyString2 is empty")
}

输出结果是:

emptyString1 is empty
emptyString2 is empty

字符串拼接

字符串之间可以相加,等号左侧必须是变量,不能是常量。
字符串变量还可以调用append方法连接其他字符。需要注意的是,append方法只能连接字符,不能连接字符串。

var combine1 = "\u{1112}"
let combine2 = "\u{1112}\u{1161}"

combine1 += combine2 //正确
combine2 += combine1 //错误

var char:Character = "a"
combine1.append(char) //正确
combine1.append("a") //即使写成这样也会报错,原因不明,可能是推导为String类型了

字符串计数

由于一个字符由若干个Unicode标量组成,所以无法使用字符串大小除以单个字符串大小来计算字符串长度。可以利用count方法来计算字符串长度:

let stringValue1 = "Hello, world"
let stringValue2 = "\u{65}\u{301}"
println("string1 length = \(count(stringValue1))")
println("string2 length = \(count(stringValue2))")
println("string2 = \(stringValue2)")

之前说过字符的自动拼接,所以运行结果如下:

string1 length = 12
string2 length = 1
string2 = é

字符串内插

这个类似于OC中的NSString stringWithFormat方法。可以通过已有字符串或数字等其他变量构建一个新的字符串,通过一个例子演示一下:

var number = 3
var time = 2
var setence = "\(number)的 \(time)倍是 \(number * time)"
println("setence = \(setence)")

对应到OC的方法,就相当于用”\()”替换了”%@”。
需要注意的是,内插的表达式中不能直接包含双引号、单引号或者反斜杠。

字符串比较

通过 == 和 != 运算符来比较字符串是否相等

比较特殊的一点是,swift在比较两个字符串时,并不会逐一比较每个Unicode标量是否相等,而是会根据字符串的实际语义来比较。所以在下面的例子中,比较结果需要特别留心一下:

var compare1 = "caf\u{E9}" //\u{E9}是带声调的e,形如é
var compare2 = "caf\u{65}\u{301}" //这是字母e加上声调合成的é
if compare1 == compare2{
    //它们依然是相等的
    println("\(compare1) is equal to \(compare2)")
}

var compare3 = "\u{41}" //拉丁字母A
var compare4 = "\u{0410}" //斯拉夫字母A
if compare3 != compare4{
    //虽然表现相同,但实际语义不同,所以字符串依然不同
    println("\(compare3) is not equal to \(compare4)")
}

运行结果如下:

café is equal to café
A is not equal to А

字符串前后缀

字符串有hasPrefix和hasSuffix方法,用于判断这个字符串是否包含某个前(后)缀,返回一个Bool类型值。注意这两个方法是区分大小写的

var preFixAndSuffix = "Hello World"
if preFixAndSuffix.hasPrefix("H"){
    println("\(preFixAndSuffix) has prefix \"H\"")
}
if preFixAndSuffix.hasPrefix("h"){
    println("\(preFixAndSuffix) has prefix \"h\"")
}
if preFixAndSuffix.hasSuffix("rld"){
    println("\(preFixAndSuffix) has suffix \"rld\"")
}
if preFixAndSuffix.hasSuffix("rldd"){
    println("\(preFixAndSuffix) has suffix \"rldd\"")
}

输出结果:

Hello World has prefix "H"
Hello World has suffix "rld"

附录

查看完整专栏——《Swift轻松入门》

【Swift入门(一)——基本语法】
【Swift入门(二)——字符与字符串】
【Swift入门(三)——元组(Tuple)】
【Swift入门(四)——可选类型(Optionals)与断言(Assert)】
【Swift入门(五)——数组(Array)】
【Swift入门(六)——字典(Dictionary)】
【Swift入门(七)——结构体(Struct)】
【Swift入门(八)——功能强大的求余运算符】
【Swift入门(九)——String与Int、Double、Float等数字相互转换】
【Swift入门(十)——循环引用、弱引用和无主引用】
【Swift入门(十一)——类型转换与is、as操作】
【Swift入门(十二)——利用Extension添加逆序输出字符串方法】

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值