关于学习文档的事情:
apple提供了很好的开发者的学习资料,下面是链接,有兴趣想学的朋友可以点击下面的链接,我就是跟着这个学习文档敲的~
https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/TheBasics.html#//apple_ref/doc/uid/TP40014097-CH5-ID309
这里又学了了一个Markdown的语法,当我们用<>,将链接扩起来的时候就可以使得链接变成超链接。
可扩展的字形群集(Extended Grapheme Clusters)
每一个Swift的Character类型代表的是一个可以扩展的字形群,不太好理解吧,举个例子,字母é可以用单一的Unicode的标量U+00E9来表示,字母e可以用Unicode的标量U+0065来表示,é头上的急促重音符号可以用Unicode的标量U+0301表示,é也可以形象的用e和急促重音符号拼接而成。
let eAcute:Character = "\u{E9}" //é
let combinedEAcute: Character = "\u{65}\u{301}" //e后面拼接上 ́
韩文中한,便可以拆分成ᄒ, ᅡ, ᆫ
let precomposed: Character = "\u{D55c}"
let decomposed: Character = "\u{1112}\u{1161}\u{11AB}"
上面的precomposed和拼接的decomposed都表示同一个值한
还可以使用包围符号包围其他的Unicode标量
let a :Character = "\u{20DD}" //是一个包围⭕️的Unicode标量
let enclosedAcute: Character = "\u{E9}\u{20DD}" //é⃝
局部的指示符号可以组合成单一的Character值
let A: Character = "\u{1F1FA}" //🇺
let B: Character = "\u{1F1F8}" //🇸
let regionalIndicatorForUS: Character = "\u{1F1FA}\u{1F1F8}" //🇺🇸
计算字符的数量(Counting Characters)
如果想要获取一个字符串的Character值的数量,就可以使用字符串的Character属性的count属性:
屏幕快照 2015-12-03 22.11.22.png屏幕快照 2015-12-03 22.12.24.png
Stackoverflow大法好!我所用的Xcode是6.3.2的版本Swift的版本是1.2,但是apple所给的swift学习文档中的特性是Swift2才有的这个特性。所以我的编译器报错。
按照别人提供的方法我又实验了一次,成功:
let unusualMenagerie = "Koala 🐨, Snail 🐌, Penguin 🐧, Dromedary 🐪"
print(" unusualMenagerie has \(count(unusualMenagerie)) characters")
// unusualMenagerie has 40 characters
访问和修改字符串(Accessing and Modifying a String)
我们可以通过字符串的属性和方法来访问和读取,也可以使用下标语法来完成
屏幕快照 2015-12-03 22.57.46.png但是同样的编译器报错了,原因跟上面是一样的。上面这段代码是我命名了一个字符串String,使用startIndex属性可以获取String的第一个Character的索引,使用endIndex可以获取最后一个Character后面一个位置的索引。注意是最后一个Character后面一个位置的索引!当String是空的时候,startIndex和endIndex是相等的。调用String.Index的predecessor()方法,可以得到前一个索引,嗲用successo()方法可以得到后面一个的索引。 屏幕快照 2015-12-03 22.44.00.png
当然下标越界的时候,会运行错误。
同样apple文档中举的这个例子也就不尝试了,编译器也会报错,在以后更新了新的Xcode7后再来熟悉这些特性。
Use the indices property of the characters property to create a Range of all of the indexes used to access individual characters in a string.
for index in greeting.characters.indices {
print("\(greeting[index]) ", terminator: "")
}
// prints "G u t e n T a g !"
你能想象简书有timeline的功能么!!!!刚才我差点覆盖了好多内容,还手贱保存了,可是我居然找回来了!!!这样用心的产品,真的是推荐!!!
网友评论